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3300 CHARACTERISTICS 


• Stored-program, solid-state, scientific and business data processing computer 

• Time-sharing and multiprogramming features 

• Parallel mode of operation 

• Diode logic 

• Character and word addressing (4 characters per word) 

• Address modification (indexing) 

• Indirect addressing 

• 28-bit storage word (24 data bits and 4 parity bits) 

• Nonvolatile magnetic core storage 

• Complete cycle time; 1.25 microseconds 

• Access time; 0. 75 microsecond 

• Storage sharing 

• Selected storage protection 

• Instruction repertoire compatible with the 3100, 3200, and 3500 Computers 

• Business oriented Moves, Searches, Edit, Compare, Conversion, and BCD 
arithmetic instructions 

• Logical and sensing operations 

• Masked storage searches 

• Block control operations 

• Trapped instruction processing 

• 24-bit accumulator register and auxiliary accumulator register 

• Binary arithmetic; 224-1 modulus, one's complement for all single pre¬ 

cision (24-bit) operations and double precision (48-bit) addition and subtrac¬ 
tion 

• 64-word register file (0, 5 microsecond cycle time) 

• Complete interrupt system 

• ASCII to BCD conversion (and vice versa) and 4-bit/6-bit packing 

• Real-time clock (1.0 millisecond incrementation) 

• Sit-down operator's console featuring; On-line typewriter and complete 
display and control system 

• Upward compatability with 3100 and 3200 computer systems 

• Standard 3000 Series type 12-bit bidirectional data channel 

• Compatible l/O mediums include magnetic tape, disk file, punched cards, 
paper tape, and printed forms 

• Options include; 

• Memory expansion to 262, 144 words (over 1 million characters) 

• Additional i2-bit data channels or high-speed 24-bit data channels 

• Floating point and 48-bit precision multiply and divide hardware logic 

• Multiprogramming hardware module 

• Business Data Processor 

• Complete selection of advanced peripheral equipment 





COMPUTER SYSTEM 


REFERENCE MANUAL 




RECORD of REVISIONS 


REVISION 


NOTES 


01 (11-16-65) 


A (5-13-66) 


(9-12-66) 


(2-23-67) 


6-14-67) 


(6-14-67) 


G (10-2-67) 


(4-4-68) 


Original printing. 


. Publications Change Order CA13641. Complete revision. All previous editions obsolete. 


Publication Change Order 14387, no Product Designation change. The following pages were 


revised or added: iii, v, vii, 1-3, 1-13, 1-14, 2-4, 2-5, 3-1 through 3-8, 4-3, 4-5, 4-8, 4-9, 


5-2, 5-7, 5-12, 5-13, 5-16, 5-18, 5-21, 5-22, 5-30, 5-41, 5-42, 5-68, 5-69, 5-73, 5-75, 5-76, 


5-79, 5-80, 5-82, 5-95.0, 5-95. 1, 5-96.0, 5-96.1, 5-98 through 5-103, 5-105, 5-106, 5-114 


through 5-123, 5-129 through 5-137, 5-140 through 5-147, 5-149, 5-151, 5-153, 5-154, 5-155, 


C-7, E-10 through E-13, Instruction Tables 6, 7, 8, 11, 12, 13, 14, 16, 17, 18. 19, 22, 24, 25, 


and 30, Index-1, Index-2 and Index-3. 


Publication Change Order 15865, no Product Desig^icition change. The following pages were 


revised or added: iv, v. 1-1, 1-10, 1-13, 1-14, 2-6, 3-3, 3-5, 3-6, 4-2, 4-3, 4-4, 4-5, 4-6, 


4-7, 4-8, 4-9, 4-10, 4-11, 5-26, 5-68, 5-69, 5-84, 5-87, 5-89, 5-91, 5-92, 5-94, 5-112, 5-116, 


5-117, 5-122, 5-144, 5-147, 5-149, 5-151, 5-155, Section 6, A-3, A-4, P-7, Index-1, Index-2, 


and Index-3. 


Engineering/Publications Change Order 16076. The following pages were revised or added; v. 


2-5, 2-6, 2-7, 2-8, 2-9 and 5-81. 


Field Change Order 16164, new Product Designation 3312-A12. The following pages were revised 


or added: 5-18, 5-21, 5-82, 5-82.0, D-10, Instruction Tables 8 and 22. 


Publications Change Order 16626, no Product Designation change. The followin 


revised or added: iii, v. 1-8. 2-1, 2-5. 2-6. 3-6. 3-7. 4-4, 4-11, 4-12, 5-3, 5-12, 5-13, 5-16, 
5-17, 5-20. 5-21. 5-22, 5-25, 5-28, 5-32, 5-33, 5-40, 5-112, 5-113, C-9. D-5, D-6, D-9, D-10, 
P-7, Instruction Tables 10. 11, 12, 13, 19, 21, 27, 28 and Index-3. 


Publication Change Order 17622. Page 5-155 revised and page 5-156 added. 


Publication Change Order 19253, no Product Designation change. Pages iii, 1-13, 1-14, 1-15 . 2-6, 
5-19, 5-127, 5 - 147, 5-155, C~ll, C-12, C-13, Inst ruction Tables 2, 14, 16 and 26 revised. 



FORM CAZ30 REV. 1-67 
































CONTENTS 


1. General Systems Description 


Introduction 1-1 

Computer Modularity 1-2 

Central Processing Unit 1-3 

Storage Modules 1-3 

Input/Output Modules 1-3 

Floating Point Module 1-4 

Multiprogramming Module 1-4 

Business Data Processor 1-4 

Operator's Console 1-4 

Power Control Panel 1-5 

Internal Organization 

Central Processing Unit 1-5 

Peripheral Equipment 1-14 

2. Storage System 

General Information 2-1 

Storage Modules 2-1 

Storage Registers 2-1 

Storage Word 2-4 

Character Modes 2-4 

Single - Character Mode 2-4 

Double - Character Mode 2-4 

Triple - Character Mode 2-4 

Full - Word Mode 2-4 

Address Mode 2-5 

Addressing 2-5 

Multiprogramming and Relocation 2-5 

Storage Protection 2-5 

Permanent Protection 2-6 

Selective Protection 2-6 

Program Protection 2-9 

No Protection 2-9 

Storage Sharing 2-9 

3. Input/Output System 

General Information 3-1 

Interface Signals 3-3 

3306 and 3307 Communication 
Channels 3-4 

I/O Parity 3-4 

Parity Checking with 3306 3-4 

Parity Checking with 3307 3-5 

Transmission Rates 3-6 

Input/Output Relocation 3-7 

Auto Load/Auto Dump 3-7 


4. Interrupt System 

General Information 4-1 

Interrupt Conditions 4-2 

Internal Condition Interrupts 4-2 

Input/Output Interrupts 4-3 

Executive Interrupt 4-3 

Storage Parity Error Interrupt 4-4 
Illegal Write Interrupt 4-4 

Trapped Instruction Interrupts 4-5 
Power Failure Interrupt 4-6 

Interrupt Control 4-7 

Enabling or Disabling Interrupt 
Control 4-7 

Interrupt Priority 4-7 

Sensing Interrupts 4-8 

Clearing Interrupts 4-8 

Interrupt Processing 4-8 

Interrupt Mask Register 4-9 

Interrupts During Executive Mode 4-11 

5. Instructions 

General Information 5-1 

Instruction Parameters 5-1 

Instruction Word Formats 5-4 

Word Addressing vs. Character 
Addressing 5-5 

Indexing and Address Modifica¬ 
tion 5-6 

Addressing Modes 5-7 

Indexing and Indirect Address¬ 
ing Examples 5-9 

Trapped Instructions 5-11 

Instruction List 5-11 

No-Operation Instructions 5-18 

Instruction Execution Times 5-19 

Halt and Stop Instructions 5-24 

Enter Instructions 5-25 

Increase Instructions 5-27 

Skip Instructions 5-2 8 

Inter-Register Transfer 
Instructions 5-32 

Jump Instructions 5-41 

Load Instructions 5-49 

Store Instructions 5-53 

Shift and Scale Instructions 5-57 

Arithmetic Instructions 5-60 

Logical Instructions 5-70 

Masked Search and Compare 
Instructions 5-75 

Condition Test Instructions 5-81 

Sensing Instructions 5-83 

Pause Instructions 5-87 

Interrupt Instructions 5-89 

Input/Output Instructions 5-92 

Relocation Control Instructions 5-112 


ill Rev. F 



Instructions (Cont'd) 

Multiprocessing Control Instruc¬ 


tions 5-113 

Conversion Instructions 5-114 

Character Search Instructions 5-124 
Move Instructions 5-137 

6. Software Systems 

General Information 6- 1 

Operating Systems 6-1 

Real-Time SCOPE 6-2 

MASTER 6-2 

MSOS 6-2 

SCOPE Utility Routines 6-2 

Languages 6-3 

FOR TRAN-3 2 6-3 

Mass Storage FORTRAN 6-3 

COBOL 32 6-3 

COBOL 33 6-4 

Mass Storage COBOL 6-4 

ALGOL 6-4 

COMPASS-32 6-4 

COMPASS-33 6-5 

Data Processing Package 6-5 

Report Generator 6-5 


Input / Output 6-5 

RESPOND/MSOS 6-6 

MSIO 6-6 

SIPP 6-6 

Applications 6-6 

PERT/TIME 6-7 

PERT/COST 6-7 

SORT 6-7 

Mass Storage SORT 6-7 

REGINA-I 6-7 

ADAPT 6-8 

7. Console and Power Control Panel 

General Information 7-2 

Console "7 “2 

Register Displays 7-2 

Instruction and Communication 
Registers 7-2 

Instruction State and Operand 
State Registers 7-3 

Data Interchange Display 7-3 

Status Display 7-4 

Switches and Controls 7-6 

Typewriter 7-19 

Power Control Panel 7-24 

Elapsed Time Meters 7-24 

Storage Protect Switches 7-24 


APPENDIXES 

A. CONTROL DATA 3100, 3200, 3300 Computer Systems Character Set 
and BCD/ASCII Code Conversions 

B. Supplementary Arithmetic Information 

C. Programming Reference Tables and Conversion Information 

D. Instruction Formats and Notes 

E. Multiprogramming and Relocation Supplementary Information 

F. Business Data Processing Supplementary Information 

GLOSSARY, INSTRUCTION TABLES, AND INDEX 


Rev. C 


iv 



FIGURES 


1-1 

3300 Modularity Example 

1-2 

5-6. 2 

77 Select Function Operation 

5-96.1 

1-2 

Computer Word Character 


5-7 

73 I/O Operation with Storage 

5-99 


Positions and Bit Assignments 

1-5 

5-8 

74 I/O Operation with Storage 

5-101 

1-3 

Block Control Scanning Pattern 

1-11 

5-9 

75 I/O Operation with Storage 

5-103 

1-4 

Parity Bit Assignments 

1-12 

5-10 

7 6 1/0 Operation with Storage 

5-105 

2-1 

3300 Storage Modules 

2-2 

5-11 

73 I/O Operation with A 

5-106 

2-2 

Optional Protect Scheme 


5-12 

74 I/O Operation with A 

5-108 

3-1 

3300 I/O System 

3-2 

5-13 

75 I/O Operation with A 

5-109 

3-2 

1/O Channel Power Panel 


5-14 

76 I/O Operation with A 

5-111 

3-3 

Principal Signals Between I/O 


5-15 

SRCE Operation 

5-126 


Channel and External Equipment 3-3 

5-16 

SRCN Operation 

5-128 

5-1 

Word-Addressed Instruction 


5-17 

Move Instruction 

5-139 


Format 

5-4 

7-1 

3300 Console 

7-1 

5-2 

Character-Addressed Instruc¬ 


7-2 

Register Display Area 

7-2 


tion Format 

5-4 

7-3 

ISR and OSR Display and 


5-3 

Business Oriented Instruction 



Binary Entry Switches 

7-3 


Format 

5-6 

7-4 

Data Interchange Display 

7-3 

5-4 

Indexing and Indirect Address¬ 


7-5 

Status Display 

7-4 


ing Routine Flow Chart 

5-8 

7-6 

Condition Switches 

7-7 

5-5 

Operand Formats and Bit 


7-7 

Access Keyboard Switches 

7-9 


Allocations for MUAQ and 


7-8 

Upper Console Switch Panel 

7-10 


DVAQ Instructions 

5-64 

7-9 

Breakpoint Switch Examples 

7-17 

5-6 

Operand Formats and Bit 


7-10 

Console Typewriter Control 



Allocations for Floating Point 



Switches 

7-19 


Arithmetic Instructions 

5-67 

7-11 

Power Control Panel 

7-25 

5-6, 

1 77 Connect Operation 

5-95.1 





TABLES 


1-1 

Register File Assignments 

1-10 

5-2 

Summary of Instruction 


1-2 

Buffer Groups 

1-11 


Execution Times 

5-12 

1-3 

BCR Conditions 

1-14 

5-3 

Interrupt Mask Register Bit 


2-1 

Storage Protection Switch 



Assignments 

5-84 


Descriptions 

2-6 

5-4 

Bit Assignments for Interrupt 


2-2 

Storage Protection Switch 



Sensing Conditions 

5-84 


Settings 

2-7 

5-5 

Internal Status Sensing Mask 

5-85 

2-3 

Optional Storage Protection 


5-6 

Pause Sensing Mask 

5-87 


Example 


5-7 

Interrupt Mask Register Bit 


4-0 

Parity Error Interrupt Codes 

4-5 


Assignments 

5-90 

4-1 

Trapped Instruction for 


5-8 

Modified I/O Instruction 



Non-Executive Mode without a 



Words 

5-93 


3310 or 3312 Module System 

4-6 

5-9 

Block Control Clearing Mask 

5-95 

4-2 

No-Operation Instruction for 


5-10 

Editing Examples 

5-153 


Non-Executive Mode 

4-6 

7-1 

Data Interchange Indicator 


4-3 

Interrupt Priority 

4-8 


Descriptions 

7-4 

4-4 

Representative Interrupt Codes 

4-10 

7-2 

Status Display Indicator 


4-5 

Interrupt Mask Register Bit 



Descriptions 

7-5 


Assignments 

4-11 

7-3 

Condition Switches Descrip¬ 


4-6 

Condition Register Bit 



tion 

7-7 


Assignments 


7-4 

Access Keyboard Switches 

7-10 

5-1 

Instruction Synopsis and Index 

5-12 

7-5 

Console Typewriter Switches 






and Indicators 

7-21 




7-6 

Console Typewriter Codes 

7-23 


V 


Rev. F 




FORWARD 


This manual provides information for the machine language use of the 3 300 computer 
system. Its intention is to describe the capabilities and programming restraints of 
the hardware. 

COMPASS mnemonics are used to abbreviate titles of instructions; however,no software 
systems are used in describing instructions. Brief descriptions of these software 
systems are included in Section 6. Detailed descriptions for those systems in operation 
are available in the appropriate software reference manuals. 

Programming information for most available peripheral equipments is contained in the 
3000 Series Peripheral Equipment Reference Manual, Pub. No. 60108800. 
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1. GENERAL SYSTEMS DESCRIPTION 


INTRODUCTION 


The CONTROL DATA* 3300 is an advanced design general-purpose computing 
system providing high performance time-sharing with multiprogramming fea¬ 
tures to satisfy present and future needs of business and scientific users. Ad¬ 
vanced design techniques are used throughout the 3300 to provide expedient 
solutions for scientific, real-time, and business data processing problems. 

Time-sharing and multiprogramming features of the 3300 enable a user to 
enter many programs and receive processed results without the delays incurred 
in single-job batch processing systems. This feature not only reduces turn¬ 
around time but also provides a considerable saving in computer usage and 
personnel time. Multiprocessing of programs further enhances system perfor¬ 
mance when additional central processors are integrated into a total system. 


Software systems for the 3300 take full advantage of the time-sharing and 
multiprogramming capabilities of the hardware and include the MASTER, 
Real-Time SCOPE, and MSOS operating systems, and the Mass Storage 
Input/Output (MSIO) system. A synopsis of each of these systems and other 
software is included in Section 6 of this manual. 


All existing programs written for CONTROL DATA 3100 and 3200 systems can be 
processed by a 3300. I/O characteristics for the 3300 are identical to the 
3100, 3200, 3400, 3500, 3600, and 3800 line of Control Data computers - a fact 
which facilitates incorporating the 3300 into a SATELLITE* configuration. 

Included in the expanded repertoire of 3300 instructions is a complete list of 
business data processing instructions. These extend the flexibility of the 3300 
by performing field searches, moves, compares, tests, conversions, arithmetic 
operations, and complete COBOL editing while utilizing the time-sharing feature 
of the 3300. 

A wide selection of proven peripheral equipment is available for use in a 3300 
system including many new and advanced equipments. 


*Registered trademark of Control Data Corporation 
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This manual describes the various features of the 3300 and provides program¬ 
ming and operation information. Reference and supplementary information may 
be found in the Appendixes. 


COMPUTER MODULARITY 


A 3300 computer consists of various logic cabinet modules designed to perform 
specific operations. If additional storage, input/output channels, or arithmetic 
capabilities are desired for an existing installation, an appropriate module is 
integrated into the system. Figure 1-1 illustrates and describes the modules 
of a typical 3300 computer. 



@ Central Processing Unit (CPU) 

(g) 2-3306 Input/Output (I/O) 

channels or 1-3307 channel 
and 1-3306 channel (Channels 
0 and 1) 

(g) 2-3306 I/O channels or 1-3307 

channel and 1-33 06 channel 

(§) 2-3306 I/O channels or 1-3307 

channel and 1-3306 channel 


© 2-3306 I/O channels or 1-3307 

channel and 1-3306 channel 

(^ Power controls for I/O channels 

©® © 

© 3310 Floating Point module 

(§) 3311 Multiprogramming module 

(J) Power Control Panel for(^ @ 
(j) 3309-8K Storage Module 


(§) 3309-8K Storage Module 


Figure 1-1. 3300 Modularity Example 

NOTES 

1. A minimum 3300 configuration consists of items @ , (§) , (© , and (j) . 

2. A 3302 16K storage module may be substituted for items (J) and © . 

(Cont'd on next page) 
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3. Additional storage modules are added to the left of item (§) . 

4. The 3312 BDP (not shown) is a "stand-alone" cable connected unit. Addi¬ 
tional storage modules may also be stand-alone units to conform to installa¬ 
tion space. 

5. 3307 I/O channels are always designated an even channel number, i. e. , 0, 2, 
4, or 6. 


Central Processing Unit 

The Central Processing Unit (CPU) is standard in all 3300 systems and performs 
the following functions: 

• Controls and synchronizes most internal operations of the computer. 

• Processes all 24-bit precision fixed point arithmetic. 

• Processes 48-bit precision addition and subtraction. 

• Executes Boolean instructions, 

• Character and word loading and storing. 

• Executes decision instructions. 

• Controls standard search and move operations, external equipment and 
typewriter I/O, real-time clock referencing, and register file operations, 

• Recognizes and processes all interrupts. 

If the Business Data Processor (BDP) is present in a system, the CPU relin¬ 
quishes control to it until the business oriented instructions(s) have been pro¬ 
cessed. 


Storage Modules 

The magnetic core storage (MCS) available for 3300 systems ranges from a min¬ 
imum of 8,192 (32,768 characters) to 262,144 (1,048,576 characters) words. An 
MCS system is expanded in 16,384 word increments after two initial 8,192 word 
storage modules are installed in the system. Up to 131,072 words of MCS may 
be included in a system without the multiprogramming option present. 

The following optional storage modules are available: 

Model 3309 - 8,192 word (32,768 characters) MCS memory module 
Model 3302 - 16,384 word (65,536 characters) MCS memory module 

The word "storage" is used synonymously with "memory" in this text and both 
refer to MCS unless otherwise stated. Additional information pertaining to the 
3300 storage system may be found in Section 2. 


Input/Output Modules 

Two types of Input/Output (I/O) modules are available for use in 3300 systems. 
These are the 3306 and 3307 Communication Channels. 

The 3306 is a bidirectional 12-bit parallel data channel and conforms to the stand¬ 
ard I/O specifications for all CONTROL DATA 3000 Computers. A maximum of 


1-3 


Rev. B 



eight 3306 channels may be incorporated in a single system with up to eight 
peripheral controllers connected to each channel. Space is provided for mount¬ 
ing two 3306 channels per module. Figure 1-1 shows the placement of the 
channels in a maximum I/O channel configuration. 

The 330 7 is a bidirectional 24-bit parallel data channel and also conforms to the 
Control Data 3000 I/O specification. In each 3307 channel 12-to 24-bit assembly/ 
disassembly is included. A maximum of four 3307 channels in addition to four 
3306 channels may be present in a single system. 

Additional information pertaining to the 3306 and 3307 I/O channels may be 
found in Section 3. 


Floating Point Module 

The optional 3310 Floating Point Module permits a user to directly execute 
floating point addition, subtraction, multiplication, and division instructions 
utilizing 48-bit precision floating point operands. This option also permits 
direct execution of 48-bit precision multiplication and division instructions. 


Multiprogramming Module 

The optional 3311 Multiprogramming Module provides capability to relocate 
program instructions, data, and I/O in MCS. This option implements the 3300 
memory page system and provides inherent memory protection as well as re¬ 
location and MCS extension to 262,144 words. If the 3311 is not present in a 
system, the maximum number of words is 131,072. Refer to Appendix E for 
additional information. 

Business Data Processor 

The optional 3 312 Business Data Processor (BDP) provides the capability to 
directly execute variable field length business data processing instructions. 
These instructions include field searches, moves, editing operations, compares, 
arithmetic operations, and binary/BCD/ASCII conversions. Delimiting is pro¬ 
vided for appropriate instructions to increase their flexibility. 

The internal organization of the BDP is further described under Internal Organi¬ 
zation in this section. 


Operator's Console 

The operators desk console includes; 

• • Octal register displays 

• Built-in on-line typewriter 

• Built-in entry keyboard and control switches 

• Complete status monitoring system 

• Operator's chair 
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A complete description of the console, examples of manual operations, and a 
picture of the console can be found in Section 7. 


Power Control Panel 

A power control panel is provided to control secondary logic power to the CPU, 
floating point module, and I/O channels 0 and 1. Other modules have their own 
power control panels. Primary power for the entire computer system is con¬ 
trolled by a group of switch boxes mounted on a nearby wall. 


INTERNAL ORGANIZATION 


Central Processing Unit 


Computer Word Format 


The standard 3300 computer word consists of 24 binary digits. Each word is 
divided into four 6-bit characters. In storage, an odd parity bit is generated 
and checked for each of the four characters, lengthening the storage word to 
28 bits. Figure 1-2 illustrates the bit assignments of a computer word in 
storage. 


23_1817_120_ 06 05 _00 

0 I I I 2 3 

\ \ / / 

Character Designators 


Figure 1-2. Computer Word Character Positions and Bit Assignments 
Register Descriptions 


A Register (Arithmetic): The A register (accumulator) is the principal arith- 
metic register. Some of the more important functions of this register are: 

• Most arithmetic and logical operations use the A register in formu¬ 
lating a result. The A register is the only register with provisions 
for adding its contents to the contents of a storage location or 
another register. 

• The A register may be shifted to the right or left separately or 
in conjunction with the Q register. Right shifting is end-off; the 
lowest bits are discarded and the sign is extended. Left shifting 
is end-around; the highest order bit appears in the lowest order 
stage after each shift; all other bits move one place to the left. 

• The A register holds the word which conditions jump and search 
instructions. 

Q Register (Arithmetic ): The Q register is an auxiliary accumulator register 
and is generally used in conjunction with the A register. 
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The principal functions of Q are: 

• Providing temporary storage for the contents of A while A is used 
for another arithmetic operation. 

• Forming a double-length register, AQ. 

• Shifting to the right or left, separately or in conjunction with A. 

• Serving as a mask register for 06, 07, and 2 7 instructions. 

E Register (Arithmetic): The optional arithmetic register E is present in a 
system whenever the 3311 Floating Point option is present in a system. During 
floating point/48-bit precision operations, the E register is divided into two 
parts, Eu* and Ep,*, each composed of 24 bits. It is used as follows: 

• 48-bit precision multiplication; holds the lower 48 bits of a 96-bit 
product. 

• 48-bit precision division; initially holds the lower 48 bits of the 
dividend; upon completion, holds the remainder. 

• Floating point multiplication; holds the residue of the coefficient 
of the 48-bit product. 

• Floating point division; holds the remainder. 

P Register (Main Control): The P register is the Program Address Counter. 

It provides program continuity by generating in sequence the storage addresses 
which contain the individual instructions. During a Normal Exit the count in P 
is incremented by 1 at the completion of each instruction to specify the address 
of the next instruction. These addresses are sent via the S (address) Bus to the 
specified storage module where the instruction is read. A Skip Exit advances 
the count in P by 2, bypassing the next sequential instruction and executing the 
following one. For a Jump Exit, the execution address portion of the jump in¬ 
struction is entered into P and used to specify the starting address of a new 
sequence of instructions. 

Registers (Main Control) : The three index registers, B^, B^, and B^, are 
used in a variety of ways, depending on the instruction. In a majority of the 
instructions they hold quantities to be added to the execution address, M=m+B^. 
The index registers may be incremented or decremented. 

C Register (Main Control) : Quantities to be entered into the A, Q, B, or P 
registers or into storage from the entry keyboard are temporarily held in the 
Communication (C) register until the TRANSFER switch is pushed. If an error 
is made while entering data into the Communication register, the KEYBOARD 
CLEAR switch may be used to clear this register. 

The C register holds words read from storage during a Sweep or Read Storage 
operation. The contents of C are displayed on the console whenever the key¬ 
board is active. 


*Eu signifies E^^ signifies . 
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F Register (Main Control): The program control register F holds an instruction 
during the time it is being executed. During execution, the program may modify 
the instruction in one of three ways; 

• Indexing (Address Modification) - A quantity in one of the index 
registers (Bt>) is added to the lower 15 bits of F for word-ad¬ 
dressed instructions, or to the lower 17 bits of F for character- 
addressed instructions. The signs of Bt> and F are extended for 
the addition process. 

• Indirect Addressing - The lower 18 bits of F are replaced by 
new'a,' 'b', and'm' designators from the original address M 
(modified if necessary, M = m + B^). 

• Indirect Addressing (load and store index instructions) - Bits 
00-14 and 1 7 of F are replaced by new 'a' and 'm' designators 
from the original address M (no modification possible). 

After executing an instruction a Normal Exit, Skip Exit, or Jump Exit is perform¬ 
ed, F is displayed on the console whenever the keyboard is inactive and the 
computer is not in the GO mode. 

Instruction State Register (Main Control): Instruction State register is a 3-bit 
register that is referenced under certain conditions when the computer is oper¬ 
ating in Executive mode. The (ISR)* are appended to the (P) in the process of 
referencing different program address groups. Refer to Appendix E for the 
different conditions when this register may be used. 


Operand State Register (Main Control) : Operand State register is also a 3-bit 
register that is referenced under certain conditions when the computer is oper¬ 
ating in Executive mode. Appendix E describes the conditions when the OSR is 
referenced with regard to the operational state of the CPU. 


Channel Index Register (Main Control): The Channel Index register (CIR) is a 
3-bit register whose contents are logically OR'ed (inclusive OR function) with 
the channel designator 'ch' for the following instructions: 


73-76 

I/O instructions 

77.0 

Connect 

77. 1 

Select Function 

77. 2 

Sense External Status 

77. 2 

Copy External Status 

77. 3 

Sense Internal Status 

77. 3 

Copy Internal Status 

77. 4 

Sense Interrupt 


This permits instructions to be written for channel 0 and allows the monitor pro¬ 
gram to assign the proper channel by altering the (CIR), The (CIR) can be trans¬ 
ferred by instruction to the lower 3 bits of the A register and vice versa. A 
momentary switch is provided on the console for displaying (CIR) in the lowest 
digit position of the Index register display area. 


*The parentheses, as they are used in this case, are an accepted method for 
expressing the words "the content(s) of" (in this case "the contents of" the ISR 
register). 
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Condition Register (Main Control) ; Bits in the Condition register (CR) are used 
as flags to initiate computer action and to record current operating conditions 
during Executive mode. With the exception of bit 04, the register is not used 
during non-Executive mode operations. 

All register bits can be set or cleared with the ACR (77. 634) instruction; selected 
bits are set or cleared by individual instructions and conditions. Refer to Section 
4 for special considerations involving the register during interrupt processing. 
The register bit assignments are listed below: 


Bit 00 

- 

Boundary Jump 

Bit 01 

- 

Destructive Load A 

Bit 02 

- 

Operands Relocated Using OSR 

Bit 03 

- 

Program State Jump 

Bit 04 

- 

Interrupt System Enabled 

Bit 05 

- 

Program State 


Data Bus Register (DBR - Main Control) : A 24-bit Data Bus register is used to 
temporarily hold the data received from storage. Communication register, and 
other logic areas. It is a nondisplayed and nonaddressable register. 

During character-addressed or I/O operations, data entering the DBR may be 
shifted one, two, or three character positions during the transfer to reach the 
correct character position within the DBR. 

Interrupt Mask Register (Main Control) : The 12-bit Interrupt Mask register 
allows a user to honor or ignore a group of various interrupts by setting the 
register bits to "I's" or "O's". Each register bit corresponds to a particular 
interrupt condition. The mask bits may be set or cleared by executing the SSIM 
and SCIM instructions, respectively. The specific mask register bit assign¬ 
ments are described in Section 4. 

S Register (Storage): The S register holds the address of the storage word 
currently being referenced. 

Z Register (Storage) : The Z register is the storage restoration and Modification 
register. Data stored or being transferred to or from the address specified by 
the S register must pass through Z. The entire storage word including the four 
parity bits is represented by the Z register and is displayed on the Storage 
Module control panel. 

Bus Systems 

The Data Bus provides a common path over which data must flow to the storage, 
arithmetic, console typewriter, and I/O sections of the computer. These sec¬ 
tions are connected in parallel to the Data Bus. During the execution of each 
instruction. Main Control determines which data transfer path is activated. 
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An odd parity bit is generated for the lower byte of each word as it leaves the 
DBR during I/O operations. In the case of a 3307 I/O Channel, parity for the 
upper byte of data is generated in the channel itself rather than in the Data Bus. 

The S or Address Bus is a data link between Main Control and storage for trans¬ 
mitting storage addresses. Inputs to the S Bus are from the P register, F reg¬ 
ister, Block Control, and the Breakpoint circuits. 

Executive Mode 

The CPU can operate in either the non-Executive mode or Executive mode. In 
non-Executive mode the 3 300 operates identically to the 3200. 

Depressing the EXECUTIVE MODE switch on the operator's console causes the 
3300 to function in the Monitor State of Executive mode. All 3300 instructions 
may be executed in the Monitor State provided the necessary hardware is pre¬ 
sent in the system. 

After executing a Set Boundary Jump (SBJP) instruction, the next jump instruction 
causes the 3300 to advance to the Program State of Executive mode. In Program 
State, the CPU performs at its highest efficiency by restricting itself to actual 
computations by not executing I/O or Block Control instructions. If a Halt (00, 0) 
instruction, any of the 71-77 instructions (except SBCD 77, 72 and SFPF 77. 71), 
or an inter-register transfer affecting registers 00 through 37 of the register file 
is attempted while in Program State, the 3300 reverts to the Monitor State of 
Executive mode. Additional information can be found in Appendix E, 

Block Control 

Block Control is an auxiliary control section within a 3300 processor. 

In conjunction with the register file and program control, it directs the following 
operations: 

• External equipment I/O 

• Search/Move 

• Real-Time clock 

• Console typewriter I/O 

• High-speed temporary storage 


Register File: The register file is a 64-word (24 bits per word) rapid access 
memory with a cycle time of 0. 5 usee. Although the programmer has access to 
all registers in the file with the interregister transfer (53) instruction, certain 
registers are reserved for specific purposes (see Table 1-1). All reserved 
registers may be used for temporary storage if their use will not disrupt other 
operations that are in progress. 

The contents of any register in the file may be viewed by selecting the register 
number with the Breakpoint switch and pressing the READ STO switch on the 
keyboard. The contents may be altered by setting the Breakpoint switch, pres¬ 
sing the WRITE STO switch, and entering a new word from the keyboard. 
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TABLE 1-1, REGISTER FILE ASSIGNMENTS 


Register 

Numbers 

Register Functions 

00-07 

Modified I/O instruction word containing the current character 
address (channel 0-7 control) 

10-17 

Modified I/O instruction word containing the last address ± 1, 
depending on the instruction (channel 0-7 control) 

20 

Search instruction word containing the current character ad¬ 
dress (search control) 

21 

Move instruction word containing the source character address 
(move control) 

22 

Real-time clock, current time 

23 

Current character address (typewriter control)* 

24-27 

Temporary storage 

30 

Instruction word containing the last character address + 1 
(search control) 

31 

Instruction word containing the destination character address 
(move control) 

32 

Real-time clock, interrupt mask 

33 

Last character address +1 (typewriter control)** 

34-77 

Temporary storage 


*The contents of register 23 should have the following format: 


23 2120 


(0-7) 


2°'^ Bit positions 


Must contain the pro¬ 
gram state number 


\ 

Slashed area should 
contain "O' s” 


"Current character address 


**The contents of register 33 should have the following format: 


23 

P7P 


1716 




/• 

Slashed area should contain "0*s' 


00 


\ 

Last character address plus one 


Block Control Priority: Access to Block Control circuits is shared between the 
computer's main program control and block control buffered functions. Functions 
within Block Control are divided into three groups (Refer to Table 1-2.) The 
five scanners that provide the priority access network for the system are the Pro¬ 
gram/Buffer scanner, the Group scanner, and the three inner group scanners. 
Figure 1-3 illustrates the scanning pattern of the priority network. 
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The Program/Buffer scanner alternately checks for Block Control requests from 
Program Control and any Group requests. Group requests have priority over 
Program requests and as long as Group requests are present, they will be serv¬ 
iced before a Program request. When all Group requests have been serviced, a 
Program request can be recognized. 

Another free running scanner checks the three groups for an active Block 
Control request. After a request from one group has been processed, the 
scanner moves to the next group, rotating through the groups in a 3, 2, 1, 3 
order. 

Each group has a four-position scanner. These scanners search from top to 
bottom of their respective groups looking for active Block Control requests. 

After they find a request and it has been processed, the scanners return to the 
top of their group before resuming their search. 


TABLE 1-2. BUFFER GROUPS 


Group 1 

Group 2 

Group 3 

Channel 0 Control 

Channel 4 Control 

Real-time clock control 

1 

5 

Console typewriter control 

2 

6 

Register File Display 

3 

7 

Search/Move Control 


CHANNEL 0 CONTROL 

1 

2 
3 



4 

5 

6 
7 



REAL-TIME CLOCK CONTROL 
CONSOLE TYPEWRITER CONTROL 
REGISTER FILE DISPLAY 
SEARCH / MOVE CONTROL 




Figure 1-3. Block Control Scanning Pattern 
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Real-Time Clock 

The real-time clock is a 24-bit counter that is incremented each millisecond to 
a maximum period of 16, 777, 216* milliseconds. After reaching its maximum 
count the clock returns to zero and the cycle is repeated continuously. The 
clock, which is controlled by a 1 kilocycle signal, starts as soon as power is 
applied to the computer. The current time is stored in register 22 of the Reg¬ 
ister File. It is removed from storage, updated, and compared with the con¬ 
tents of register 32 once each millisecond. When the clock time equals the 
time specified by the clock mask, an interrupt is set. When necessary, the 
real-time clock may be reset to any 24-bit quantity including zero by loading A 
and then transferring (A) into register 22. Performing a Master Clear does not 
affect the clock count. 

For a special case involving the real-time clock, refer to the Priority Pause 
(PRP) instruction in Section 5, 

Parity 

Parity bits are generated and checked in 3300 systems for the following two 
conditions: 

1. Whenever a data word is read from or written into storage. 

2. When a data word is transferred via an I/O channel. 

Storage Parity : A parity bit is generated and checked for each 6-bit character 
of a storage word. Refer to Figure 1-4. 


27 26 2524 23 _ 18 17 _ 12 II _ 06 05 _00 

hhKN ^ I ' I ^ I ^ ~ 

\ / / 

CHARACTER DESIGNATORS-' 

PARITY BIT FOR CHARACTER 3 
PARITY BIT FOR CHARACTER 2 
PARITY BIT FOR CHARACTER I 
PARITY BIT FOR CHARACTER 0 


Parity Bit Assignments 

During each Write cycle, a parity bit is stored along with each character. 

When part or all of a word is read from storage, parity is checked for a loss or 
gain of bits. Failure to produce the correct parity during read operations 
causes the PARITY FAULT indicators on the storage module control panel and 
internal status lights to glow. As soon as a parity error is recognized and the 
PARITY STOP switch on console is active, program execution is halted. Master 
clearing the computer clears the fault condition. 

If the PARITY INTERRUPT switch is active and an interrupt is recognized, the 
computer enters a special interrupt routine (see Section 4). 



Figure 1-4. 


*16, 777,216 milliseconds equals approximately 4 hours and 40 minutes. 
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The total number of "I's” in a character, plus the parity bit, is always an odd 
number in the odd parity system used in the 3300. 

I/O Parity : The I/O communication channels provide parity lines in addition 
to the other signals that interface with external equipment. Parity is checked 
in the I/O channels to detect parity errors during data transmission to the ex¬ 
ternal equipment and errors when data is received from external equipment. 
I/O parity errors can be detected by a sensing instruction; however, the parity 
error indicator is not activated. A complete description of I/O parity genera¬ 
tion and checking may be found in Section 3 of this manual. 


Business Data Processor (BDP) 

The BDP is an optional processor capable of directly executing the business 
oriented instructions listed below and on the next page by their mnemonic codes 
and explained in detail within Section 5. 


64,0 

MVE and MVE, DC 




64, 1 

MVBF 




64.2 

MVZF 




64, 3 

MVZS and MVZS, DC 




67,2 

ZADM 




64. 4 

FRMT 




64.4 

EDIT 




65.0 

SCAN, LR, EQ and SCAN, 

LR, 

EQ, 

DC 

65.2 

SCAN, LR, NE and SCAN, 

LR, 

NE, 

DC 

65.1 

SCAN, RL, EQ and SCAN, 

RL, 

EQ. 

DC 

65. 3 

SCAN, RL, NE and SCAN, 

RL, 

NE, 

DC 

66.0 

CVDB 




66.1 

CVBD 




66.2 

DTA and DTA, DC 




66. 3 

ATD and ATD, DC 




66.4 

PAK 




66. 5 

UPAK 




67.0 

ADM 




67.1 

SBM 




67. 3 

CMP and CMP, DC 




67,4 

TST and TSTN 




70. 6 

LBR 




70. 7 

sb'R 





Upon command from the CPU, the BDP executes the BDP instructions as they 
occur in the program. These instructions all require three instruction words 
(referred to as sub-instruction words) and are stored consecutively, i. e, , at the 
current address defined by P, Pfl, and P+2. After executing one of the BDP 
instructions, the processor relinquishes program control to the CPU for con¬ 
tinued program execution. 


If an interrupt occurs during a BDP instruction, the BDP relinquishes control to 
the CPU after the current character operation is completed. When the CPU fin¬ 
ishes interrupt processing, the instruction that was interrupted is again read 
from memory. A restart is usually made at the point of interrupt (CVDB and 
CVBD instructions restart at the beginning - also refer to Illegal Write interrupt 
in Section 4). 


1-13 


Rev. H 



3 

(B ) is used to indicate at what point in the BDP operation |;he interrupt occurred, 
plus arithmetic carry and second pass information: 


• bit 12 of B^ 

• bit 13 of B3 

• bit 14 of B^ 


"1" if a second pass (complementing operation) was in 
progress. 

"1" if an arithmetic carry was generated on an ADM or 
SBM instruction during the iteration prior to interrupt. 
This bit is used for internal machine status to enable 
recovery from an interrupt and must not be construed 
to indicate an arithmetic overflow at instruction 
completion. 

"1” if floating insertion is set on EDIT. 

"l” if a BCD fault occurred. 


• bits 00-11 represent the number of characters or words operated on 
in field C prior to entering the interrupt routine. 


The BDP Condition register (BCR) is a 2-bit register located in the BDP. This 
register is set for conditions existing directly after a business data processing 
operation has occurred. (Refer to Table 1-3. ) The (BCR) are sampled by the 
CPU and a jump may then occur. Refer to the JMP, ZRO; JMP, HI; and JMP, 
LOW instructions. 


TABLE 1-3. BCR GONDITIOIS'S 


(BCR)* 

Significance 
for Compare 
(CMP) Instr. 

Significance 
for Arithmetic 
(ADM & SBM) 
Instructions 

Significance 

for Other Instructions 

OO 2 

Field A = Field C 

- 

- 

<>‘2 

Field A > Field C 

result positive 

operand positive 

1°2 

Field A < Field C 

result negative 

operand negative 


*ll 2 code is unassigned. 


For BDP instructions containing two fields of variable length, the two fields may 
be assigned as required in memory. However, care should be taken so that over¬ 
lapping of processed data from the result field and unprocessed data from the 
source field does not occur. The results may be unpredictable if overlapping 
occurs. 

Additional information can be found with the individual BDP instructions in 
Section 5 and Appendix F. 
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PERIPHERAL EQUIPMENT 


A wide variety of peripheral equipment is available for use with the 3300 com¬ 
puter, All peripheral equipment available for 3100, 3200, 3300, 3400, 3600, 
and 3800 systems may be attached to a 3306 communication channel. For pro¬ 
gramming instructions, as well as a list of function codes and status response 
codes, refer to the Control Data 3000 Series Computer Systems Peripheral 
Equipment Reference Manual (Pub. No, 60108800). 
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2. STORAGE SYSTEM 

GENERAL INFORMATION 


The 3300 Magnetic Core Storage (MCS) system receives and transmits storage 
words to the CPU (and BDP if it is in the system). Each storage module pro¬ 
vides parity checking and visual address and data displays. Each storage (or 
memory) reference requires 1.25 usee within the storage module referenced 


STORAGE MODULES 


A minimum storage configuration consists of one 3 309 8, 192 word Storage 
Module. An additional 3309 Storage module brings the total storage capacity 
to 16, 384 words. Further storage expansion is provided by adding model 3302 
16, 384 word Storage modules. If the 3300 is equipped with a 3311 Multipro¬ 
gramming module, 3302 Storage Modules may be added to bring the total MCS 
capacity to 262, 144 words. If the 3311 is not in the system, the maximum MCS 
is 131, 072 words. The 3309 and 3302 Storage modules are shown in Figure 2-1 
along with an enlarged view of their control panels. 


STORAGE REGISTERS 


S Register - The S register receives and holds the storage address, enabling 
address translation for the word currently being referenced. The register 
consists of 13 bits and 14 bits, respectively, in the 3309 and 3302 storage 
modules. 

Z Register - The 28-bit Z register is the storage restoration and modification 
register. All data that is transferred to or from the storage module passes 
through Z. 
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Figure 2-1. 3300 Storage Modules (Cont'd) 
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STORAGE WORD 


A storage word is 28 bits in length of which four bits are used for parity- 
checking the remaining 24 bits. The 24 bits, labeled 00 through 23 from right 
to left, may be a single 24-bit instruction, part of a two or three word instruc¬ 
tion, a zero to 24-bit operand, or part of a larger operand. The storage cor¬ 
responds to the standard computer word and its format as described in Section 
1 . 


CHARACTER MODES 


During a read storage operation, all bits of a word referenced by (S) are read 
out of core storage into the Z register (in parallel) and are restored without modi¬ 
fication at the same address. For a write storage operation, five basic modes 
exist for modifying (Z) prior to restoration. Any characters not modified are 
restored unchanged. Write Character Designators from the computer or other 
access devices specify the type of write operation to be performed. 


Single-Character Mode 

New data is entered into any one of the four characters prior to restoring the 
word in core. 


Double-Character Mode 


New data is entered into any two adjacent characters (character 0 and 1, 1 and 2, 
or 2 and 3) prior to restoring the word in core. 


Triple-Character Mode 

New data is entered into either of the two possible three-character groups (charac¬ 
ters 0, 1, and 2, or characters 1, 2, and 3) prior to restoring the word in core. 


Full-Word Mode 

New data is entered into characters 0-3 prior to restoring the word in core. 
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Address Mode 

New data is entered into the lower 15 bits (word address) or the lower 17 bits 
(character address) prior to restoring the word in core. 


ADDRESSING 


The S bus, as described under Bus Systems in Section 1, carries the address of 
the memory location being referenced to the proper storage module. During 
Executive mode, the (ISR)* or (OSR)* are appended to a 15-bit basic address (as 
displayed in the P register) to form an 18-bit address. The upper 3 bits of add¬ 
ress are forced to zero during non-Executive mode to limit storage addressing 
to 32, 768 words. 

If a storage reference is made for an address contained in a non-existent 
memory module, a high priority interrupt may be entered. Refer to the Storage 
Parity Error-No Response Interrupt in Section 4 for details. 


MULTIPROGRAMMING AND RELOCATION 


The 3311 Multiprogramming Module permits the instructions of many programs 
to be sequentially executed and relocated in MCS under the control of a monitor 
program. The available MCS in a 3300 system is grouped into "memory pages" 
consisting of 2, 048 absolute memory locations. By using a Page Index File and 
advanced logic circuits, the 3311 makes optimum use of memory pages as they 
become available during program execution. 

Appendix E includes detailed information on multiprogramming and relocation 
concepts as applied to the 3300. 


STORAGE PROTECTION 


It is often desirable to protect the contents of certain storage addresses against 
alteration during the execution of a program. There are four categories of ad¬ 
dresses: those that are always protected, those that are protected at the option 
of the programmer, those that are protected by the multiprogramming and re¬ 
location features, and those that are never protected during special sequences. 

If any attempt is made to write at a protected address during non-Executive mode, 
the illegally addressed location remains unaltered (Write is changed to a Read), 
the console Illegal Write indicator lights, and program execution continues. The 
illegal write condition is recorded by setting bit 05 of the internal status sensing 
network. The condition is cleared by a Master Clear, an Internal Clear, or by 
sensing. 

* Only the numbers 0, 1, 2 and 3 in the ISR or OSR can be used in the Multipro¬ 
gramming option is not in the system. 
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During Executive mode, a protected address remains unaltered (Write is changed 
to a Read) during all write operations, except those occuring in Monitor State 
and during Block Control operations. The condition is not recorded on the status 
line. Refer to the Illegal Write interrupt discussion in Section 4 for additional 
information. 

Permanent Protection 

The upper 32 memory locations of the existing MCS are reserved for Auto Load 
and Auto Dump programs when operating in the non-Executive mode. These 
addresses are always protected against alteration by a special storage protec¬ 
tion circuit. The actual protected addresses depend upon the number of MCS 
locations in a system but always utilize the upper 32 locations in any system. 

Logic circuits sense the total storage capacity of the system and check each 
storage address as it appears on the S (address) Bus to see if it is among the 
protected addresses. If it is one of those to be protected, reading, but no writ¬ 
ing, is allowed at that address. The only time that this protection is disabled 
is when an operator presses the ENTER AUTO PROGRAM switch on the console 
to enter a new Auto Load or Auto Dump program. 

When operating in Executive mode, the Auto Load and Auto Dump storage areas 
encompass addresses 003700g through 003777o and are protected when referenced 
through Page Index Zero. Refer to Section 3 for additional information on the 
AutO' Load and Auto Dump features. 


Selective Protection 

3304-A Central Processor 

Two different selective protect schemes are available with the 3304-A; one being 
standard and the other available by option. In the standard protect scheme, 15 
three-position toggle switches, corresponding to the basic 15-bit storage address, 
are set to selectively protect Individual addresses or a block of addresses. The 
switches are located on the power control panel as shown in Section 7. 

Table 2-1 describes the three switch positions and Table 2-2 lists examples of 
switch settings. The switches are automatically disabled during execution of the 
BDP instructions (64-70). In Executive mode, the switches apply to an address 
range of which the upper 3 address bits (ISR) or (OSR) are equal to zero. 


TABLE 2-1. STORAGE PROTECTION SWITCH DESCRIPTIONS 


Output 

Switch 

Position 

Description 

11^ TI 

Up 

Each address protected will have a "l" in this bit position. 

"N” 

Center 

Each address protected may have either a "l" or a "O" in 
this position. For example, when all switches are set to 
the neutral position, all storage is protected, provided ■ 

that the protect feature is enabled. 

"0" 

Down 

Each address protected will have a "O" in this bit position. 
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TABLE 2-2. STORAGE PROTECTION SWITCH SETTINGS 



Examples: 

Description of Protected Addresses 

Se ttings - Sto r a ge 
Protection Switches 

Addresses 
Protected (octal) 

Single storage address 

000 000 000 001 111 

00017 

Two nonsequential addresses 

000 000 000 010 ONO 

00020 & 00022 

of a group of lOg.* 

000 000 000 010 NIO 

00022 & 00026 

Four nonsequential addresses 
of a group of lOg.* 

000 000 000 010 NON 

000 000 000 010 NNl 

00020 , 00021 , 
00024, & 00025 
00021, 00023, 
00025, & 00027 

Four address block - may be the 

000 000 000 100 ONN 

00040-00043 

upper or lower half of a group of 
lOg. * 

000 000 000 100 INN 

00044-00047 

lOg address block 

000 000 000 010 NNN 

00020-00027 

203 address block 

000 000 001 OON NNN 
000 000 001 IIN NNN 

00100-00117 

00160-00177 

403 address block - may be the 

100 000 000 ONN NNN 

40000-40037 

upper or lower half of a group 
of lOOg. * 

100 000 000 INN NNN 

40040-40077 

Numerous other groups and com¬ 
binations of the above groups 

000 000 000 NNN 110 

00006, 00016, 
00026 . . . 00076 

may also be protected. 

NNN NNN NNN NNN 111 

NNN NNN 001 NNN NNN 

All XXXX7 ad¬ 
dresses 

All XXIXX ad¬ 
dresses (00100- 
00177, 01100- 
01177, etc.) 


*The first address of all groups of lOg, 203 , 408, lOOg etc., must have a low¬ 
er octal digit of zero. Blocks of lOOg, 2000, 4008, lOOOg, 20008, 40008, etc,, 
may be protected in the same manner as blocks of lOg, SOg, & 408. 


The optional protect scheme allows two independent blocks of locations within a 
designated 32K of storage to be protected during non-Executive or Executive 
mode. With this feature, protection can be given to the resident monitor program 
and to another program that may be operating. 

The area increasing in address from address 00000 may be protected in multiples 
of 512 j^q locations. The area decreasing from address 77777 can similarly be 
protected. The number of locations protected in an area is determined by setting 
the six toggle switches associated with that area; each of the 77 0 possible settings 
represents one multiple of 512 locations. The six switches labmed 9 through 14 
select the lower protected area; those labeled 0 through 5 select the upper 
protected area (refer to Figure 7-11) . Figure 2-2 illustrates the protection 
scheme. Table 2-3 gives examples of switch settings and their corresponding 
protected areas. 


2-7 


Rev, D 












Switch settings for both schemes are disabled by pressing the DISABLE STO 
PROTECT switch on the console. 


ADDRESS 77777 


B X X (17 1 ) 


CXX (000) 


ADDRESS 00 000 

Bxx = 6 switches to select upper area address boundary, lower 9 bits of which 
are always " I's" 

Cxx = 6 switches to select lower area address boundary, lower 9 bits of which 
are always "O's" 


PROTECTED 


UNPROTECTED 


PROTECTED 


Figure 2-2. Optional Protect Scheme 
TABLE 2-3. OPTIONAL STORAGE PROTECTION EXAMPLES 


Bxx 

Setting 

Locations Protected 
(Upper and Lower areas) 

Cxx 

Setting 

76 

OlOOOg = 512 

01 

75 

02000g = 1, 024 

02 

74 

OSOOOg = 1,536 

03 

67 

lOOOOg = 4,096 

10 

57 

20000g = 3, 192 

20 

40 

37000g = 15, 872 

37 

37 

40000g = 16,384 

40 

36 

41000„ = 16,896 

o 

41 
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3304-B Central Processor 


The basic 3304-B Central Processor contains no standard storage protection. 
Storage protection is available by option and operates the same as the optional 
protection which is available on the 3304-A processor. 


Program Protection 

When the 3 300 is operating in the Program State of Executive mode, the reloca¬ 
tion features of the 3311 Multiprogramming module are used by the monitor 
program to protect certain addresses from being altered. 

if the exclusion bit of a particular Page Index is a "1" and PL, f PA, t or PPt 
is a quantity other than zero, PA defines a memory area where only reading is per¬ 
mitted. If the exclusion bit is ”1'' and PL, PA,and PP are all equal to zero, 
neither reading nor writing is permitted. 


The monitor program controls the relocation process and uses the paging 
system to provide efficient use of memory while processing various programs. 
Appendix E explains in detail the 3300 paging and relocation processes. 


No Protection 

Addresses 00002 through 00005, 00010, 00011, 00014, 00015, 00020, and 
00021, which are used by the interrupt system, are never protected during the 
interrupt sequence. 


STORAGE SHARING 


Two 3300 computers may share the memory of a storage module. A switch on 
each storage module control panel allows the operator to give exclusive control 
to the right or left computer. A middle position on this switch actuates a two- 
position priority scanner. Storage control honors the requests in the order 
they are received. Neither computer has priority over the other and the com¬ 
puter involved in the current storage cycle relinquishes control to the request¬ 
ing computer at the end of its cycle. Either computer can therefore be delayed 
a maximum of one storage cycle. A similar program delay may occur within 
either computer when an internal scanner determines whether Main Control or 
Block Control has access to the storage module. 

Direct access to 3300 type storage modules is available for certain installations. 
The normal I/O channel route is bypassed and the customer's special equipment 
interfaces directly with the storage logic. 


tRefer to Appendix E for designator descriptions. 
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3. INPUT/OUTPUT SYSTEM 


GENERAL INFORMATION 


Data is transferred between the 3300 Central Processor and Its associated periph¬ 
eral equipment via a 3306 or a 3307 Communication Channel. The 3306 utilizes 
a 12-bit parallel-transfer byte and the 3307 provides a 24-bit byte. A maximum 
of eight 3306's or four 3307's and four 3306's may be linked to a single system. 
Both the 3306 and the 3307 are bidirectional and each channel may communicate 
with a maximum of eight peripheral controllers. A data channel can communicate 
with only one device at a given time, however. Each peripheral controller in 
turn may be attached to a number of peripheral devices. Figure 3-1 is a simpli¬ 
fied block diagram of a 3300 Communication System. 

For programming purposes, the eight possible I/O channels are designated by 
numbers 0 through 7. A 3307 channel will always be an even channel. The total 
number of channels must always be even. Depending upon the user's needs, any 
combination of 3306's and 3307's may be present provided all the forenamed rules 
are followed. 

A basic 3300 system includes two 3306 Communi cation Channels or one 3307 
channel and one 3306 channel. Figure 1-1 indicates the location of these channels 
in a fully expanded system. 

Channels 0 and 1 derive their operating power from the CPU. Power for all other 
channels is controlled through the I/O Channel Power Panel shown in Figure 3-2 
and as F in Figure 1-1. The two voltage controls should be adjusted to produce 
0% reading on the meters when the 400 cycle power circuit breaker is turned ON. 
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Equipment 
_A 


Data Channel 



A maximum configuration of data channels. A smaller configuration may be 
obtained by removing the channels in pairs of odd and even. Any 3307 may be 
replaced by a 3306, but not vice versa. 

Each channel may connect to a maximum of eight equipments. The number of 
devices connected to an equipment depends upon the equipment. 


Figure 3-1. 3300 I/O System 



VOLT METER 


VOLTAGE CONTROL 


VOLT METER 


VOLTAGE CONTROL 


400 CYCLE POWER CIRCUT BREAKER 


Figure 3-2. I/O Channel Power Panel 
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INTERFACE SIGNALS 


Figure 3-3 shows the interface signals between a data channel and its external 
equipment. The twelve status lines are active only between the channel and the 
controller to which it has been connected by a CON (77. 0) instruction. Since a 
Connect instruction causes all controllers on the specified channel to disconnect 
except the one to which it is directed, only one controller may be connected to a 
channel at one time,. Thus to check status the program must first Connect the 
device. 

There are eight interrupt lines, one to each controller. A controller need not be 
connected to return an interrupt signal to the data channel. These lines are 
designated as 0-7 and match the Equipment Number switch setting on each con¬ 
troller. For a complete description of the I/O interface signals as well as an I/O 
timing chart, refer to the 3000 Series Input/Output Specifications Manual, Pub. 
No. 60048800. 



Figure 3-3. Principal Signals Between I/O Channel and External Equipment 
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3306 AND 3307 COMMUNICATION CHANNELS 


Communication channels provide a biaffer between the computation section and 
various peripheral controllers, thus preventing a tie-up of the computation section 
while awaiting a response from an external equipment. Since an I/O section con¬ 
tains no manual controls or indicators, all operations must be initiated by program 
via the computation section of the computer. Prior to actual data exchange the 
program must execute several instructions which connect the equipment to the 
channel, specify operating conditions, check status conditions, and initiate the 
Read orWrite operation. After the Central Processor initial es the Input or Output 
operation, a communication channel can exchange data between the peripheral 
device and core storage independent of the Central Processor. 

All assembly and disassembly for the 3306 12-bit channel is done by block control, 
not the 3306. Two memory references are necessary to store or transmit a 24- 
bit word when doing a word addressed I/O instruction with 12- to 24-bit assembly. 
In contrast, the 3307 contains its own assembly/disassembly feature. The assem¬ 
bly feature allows the channel to receive two 12-bit bytes from an external equip¬ 
ment and assemble them into a 24-bit word before storing in memory. The dis¬ 
assembly feature permits the channel to accept a 24-bit word from storage and 
transmit it to an external equipment in 12-bit bytes. 

The 3307 also facilitates a convenient interface with a 24-bit I/O device. The 
24-bit transfers between memory and the 3307 reduce to one the number of mem¬ 
ory references necessary to execute a word addressed I/O instruction. Thus the 
3307 is adapted for use with high-speed 12- and 24-bit I/O devices. When doing 
character addressed instructions, it acts as a 3306. 

I/O PARITY 


Parity Checking With the 3306 

The computer checks parity by one method for Connect, Function, and Write 
operations and by a second method for Read operations. External equipment 
responds differently to parity errors for a Connect than for a Function, Read, 
or Write. For details on external equipment responses to parity errors see 
3000 Series Peripheral Equipment Reference Manual, Pub. No. 60108800. 

Connect. Function, and Write 

During the Connect, Function, and Write operations the Data Bus circuit of the 
computation section generates a parity bit and sends it to the external equipment 
with each 12-blt byte via the I/O channel. The external equipment generates a 
parity bit and compares it with the parity bit from the computer. 

Connect: If a parity error exists in a Connect instruction, the external equipments 


• do not connect 

• disconnect if already connected 
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• do not return an External Parity Error signal 

• generally light a Parity Error indicator on the external equipment, and 

• return neither a Reply nor a Reject signal. 

After 100 usee the computer issues an Internal Reject. 

Function and Write: If a parity error exists in a Function or Write instruction, 
the connected external equipment sends an External Parity Error signal back to 
the I/O channel. This signal causes the logic within the channel to provide a "1" 
on sense line zero. This logic is cleared every time an attempt is made to exe¬ 
cute a Connect, Function, Read, or Write operation on this channel; however, 
these operations do not necessarily clear the logic in the external controller that 
transmits the External Parity Error signal. Thus to guarantee clearing this 
sense line the external equipment must also be cleared. Both the I/O channel 
and the external equipment may be channel cleared by the program or master 
cleared by the operator. If a transmission parity error is received from a con¬ 
troller, the controller remains inactive until both the external equipment and the 
I/O channel are cleared. A new I/O sequence must be initiated to continue or 
repeat the I/O operation. 


Read 

During a Read operation, the external equipment generates a parity bit and sends 
it to the I/O channel along with each 12-bit byte of data. The I/O channel holds 
the parity bit while the data is forwarded to the computation section. The Data 
Bus circuit of the computation section generates a second parity bit and sends it 
back to the I/O channel. The channel compares this second signal with the Parity 
signal which was generated by the external equipment. H an error exists, certain 
channel logic is set by an enable from the computation section. This logic provides 
a "1" on sense line zero. The channel parity logic is cleared every time an attempt 
is made to execute a Connect, Function, Read, or Write operation with this chan¬ 
nel. It may also be channel cleared by the program or master cleared by the 
operator. If a transmission parity error is channel generated, it must be sensed 
by the INS instruction. If th.e error is not sensed, the next channel operation 
clears the error indication. 


Parity Checking With the 3307 

The computer checks parity with a 3 307 in a slightly different manner than with a 
3306. 

Connect. Function, and Write 

During the Connect, Function, and Write operations the Data Bus circuit in the 
computation section generates one parity bit for the lower 127 bit byte of data and 
one parity bit for the upper 12-bit byte. Both parity bits are sent to the external 
equipment via the I/O channel. The external equipment generates parity bits and 
compares them with the parity bits from the computer. The remainder of the 
parity checking is identical to that of the 3306 for Connect and for Function and 
Write. 
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Read 


During a Read operation, the external equipment generates two parity bits per 
data word (one for each 12-bit byte) and sends them to the 3307 with the word. 
The 3307 holds the parity bits as the data is forwarded to the Data Bus circuit 
of the computer. Parity is generated in the Data Bus circuit and is sent back 
to the I/O' channel where a comparison is made with the parity bits received 
from the external equipment. 


If a parity error exists, the channel parity logic is set by an enable from the 
computation section, thus providing a "1" on sense line zero. Clearing the logic 
also occurs the same way as it does in the 3306. If a transmission parity error 
is channel generated, it must be sensed by the INS instruction. If the error is 
not sensed, the next channel operation clears the error indication. 


TRANSMISSION RATES 


The rate of transmitting each 12-bit word of I/O information depends upon the 
number of channels active, interregister transfers, the use of pause instructions 
to block out main control or the real-time clock, the length of connecting cables, 
and the use of multiprogramming. The 3000 Series Input/Output Specifications 
Manual, Pub. No. 60048800, describes in detail the measurement of these transfer 
rates using a variable-speed channel execiser. The exerciser meastires the trans¬ 
fer rate by indicating a Lost Data condition when its speed exceeds that of the data 
channel. Word addressed I/O instructions with 12- to 24-bit Assembly/Disassem- 
bly were used. 


Assuming a safe maximum transfer rate to the 10 percent slower than the average 
of the rates at which a Lost Data condition occurred, the following cases serve as 
examples of realizable transfer rates. 


Without multiprogramming: 

1. Using a 3307 on channel 4, doing 
I/O only, blocking main control 
and the real-time clock with a 
Priority Pause instruction. 

2. Standard rate, no restrictions on 
program, channel 0 and 1 active, 
channel 0 is a 3307, channel 1 is 
a 3306. 


Maximum Transfer Rate 
(12-bit word) 


2 . 0 usee 


8 . 0 usee (channel 0) 
20 . 0 usee (channel 1) 
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With multiprogramming 

1. Using a 3306 on channel 0, 
doing 1/O only, blocking main 
control and the real-time clock 
with a Priority Pause. 

2. Standard rate, no restrictions 
on program, channels 0 and 4 
active, both are 3306's. 


4. 2 usee 


16. 0 usee (channel 0) 
16. 0 usee (channel 4) 


The measured transfer rates when doing relocation were 0. 2-. 3 usee greater. 


INPUT/OUTPUT RELOCATION 


Data may be transmitted to or from several block locations in storage by using 
relocation. When an I/O instruction is encountered while executing a program in 
Executive Mode, Program State, an Executive Interrupt returns the computer to 
Monitor State. When a 3311 is present in the system the relocation of I/O infor¬ 
mation now occurs in the same manner as the relocation of a program. The mon¬ 
itor recognizes and assigns the appropriate I/O channels and devices. Whether 
or not relocation occurs, the largest block of data which may be transferred by 
a single I/O instruction is 32K 24-bit words. 


AUTO LOAD/AUTO DUMP 

The Auto Load and Auto Dump feature of the computer allows the programmer 
two groups of continuous storage locations for storing frequently used subrou¬ 
tines, These subroutines may be used whenever it is desirable to call in a 
particular tape unit or some other function that initiates an operation. 

By depressing the AUTO LOAD console switch when the computer is stopped 
and in the non-Executive mode, the computer automatically jumps to address 
77740 and executes the instruction stored there. The Auto Load routine is 
allotted sixteen addresses, 77740 through 77757. 

Depressing the AUTO DUMP switch under the same conditions as Auto Load 
causes the computer to jump to address 77760 and execute the instruction stored 
there. Sixteen addresses, 77760 through 1111 % may be used for the Auto Dump 
routine. 

Although these storage areas may be used for any routine, the Auto Load area 
is generally used to bring in a program from a magnetic tape unit or other 
peripheral device. The last instruction in this routine should be a jump to the 
first address of the program just called in. 

The Auto Dump area is most often used to output a block of data to a magnetic 
tape unit or other peripheral equipment and the last instruction in this routine 
can be a jump to any storage area within the confines of the system. 
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When the computer is operating in Executive mode, the Auto Load routine is 
stored in thirty-two locations encompassing addresses 003700 through 003737. 

The Auto Dump likewise has thirty-two locations ranging from address 003740 
through 003777. The PA and PP designators of the page index associated with 
Page Index File zero are always zero thus providing a definitive area of storage 
(page zero) where the Auto Load and Auto Dump routines may be stored. The 
Auto Load and Auto Dump addresses are always protected in Non-Executive mode. 


Examples of entering programs into the Auto Load and Auto Dump storage 
areas are given in Section 7. 



4. INTERRUPT SYSTEM 


GENERAL INFORMATION 


The Interrupt System of a 3300 Computer can sense for the presence of certain 
internal and external conditions without having these tests in the main program. 
Examples of these conditions are internal faults and external equipment end-of- 
operation. Near the end of each RNI cycle, a test is made for interruptible 
conditions. If one of these conditions exists, and the interrupt system is en¬ 
abled; execution of the main program halts, the contents of the Program Ad¬ 
dress register are stored, and an interrupt routine is initiated. This interrupt 
routine previously stored in memory, performs the necessary functions for the 
existing condition and then jumps back to the last unexecuted step in the main 
program. The instruction being read when the interrupt is recognized is exe¬ 
cuted when the main program is resumed. 

There are seven categories of interrupts in the 3300 Computer: Internal Condi¬ 
tion interrupts, I/O interrupts. Executive interrupt. Parity Error interrupt. 
Illegal Write interrupt. Trapped Instruction interrupts, and Power Failure in¬ 
terrupt. The store operations required for all types of interrupts occur regard¬ 
less of the settings of the storage protection switches described in Section 2. 

An additional programming feature is the MANUAL INTERRUPT switch on the 
operator's console. This interrupt is not masked since this switch is activated 
only when it is desirable to interrupt the computer, however, the interrupt 
system must be first enabled. The manual interrupt condition is automatically 
cleared after the interrupt is recognized. 

When the 3300 is operating in the Program State of Executive mode, any inter¬ 
rupt that is recognized causes the processor to revert to the Monitor State. An 
Executive interrupt (described later in this section) also causes the processor 
to revert to the Monitor State if an attempt is made to execute one of several 
particular instructions. 
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INTERRUPT CONDITIONS 


Internal Condition Interrupts 

Any one of six internal conditions may cause an interrupt during the execution 
of a program. These conditions and their descriptions follow. 

Arithmetic Overflow Fault 

The Arithmetic Overflow fault is set when the capacity of the adder is exceeded. 
Its capacity, including sign, is 24 or 48 bits for 24-bit precision and 48-bit 
precision, respectively. 

Divide Fault 

The Divide fault sets if a quotient, including sign, exceeds 24 or 48 bits for 
24-bit precision and 48-bit precision, respectively. Therefore, attempts to 
divide by too small a number, including positive and negative zero, result in a 
Divide fault. A Divide fault also occurs when a floating point divisor is either 
equal to zero or not in floating point format. The results in the A, Q, and E 
registers are insignificant if a fault occurs. A Divide fault can be correctly 
sensed only after the current instruction has been executed. 

Exponent Overflow/Underflow Fault 

During all floating point arithmetic operations, exponential overflow occurs if 
the exponent exceeds +1777o or is less than -1777o. The fault is also set if 
the SFPF (77. 71) instruction is executed. 

BCD Fault 

The BCD fault is generated by the BDP module if: 

1. The lower 4 bits of any character in field A (except the sign character) 
exceed llg during a numeric character operation. 

2. The lower 4 bits of the sign character in field A exceed 12g during a 
numeric character operation. 

3. The upper 2 bits of any character in field A (except the sign character) 
do not equal 00 during a numeric character operation. 

4. An arithmetic carry out of the highest order character of field C occurs 

during an ADM or SBM instruction. _ 

5. Field length Si> S2 ADM or SBM instruction. 

6 . Field length Sj ^ S 2 ^ PRMT instruction, including provision for 
insertion characters. 

7. A carry occurs out of the 14th character position during a CVBD 
instruction. 

8 . A field (Sj) of more than 14 BCD characters is specified during a CVDB 
instruction. 

9. Bits 05 and 06 of an ASCII character are both "I's” or both "O's” during 
the execution of an ATD instruction. 

The BCD Fault may also be set by executing the SBCD (77. 72) instruction. 
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Search/Move Interrupt 

The Search/Move control may be programmed to generate an interrupt during 
a 71 or 72 instruction for either of the following conditions; 

1. Completion or satisfaction of an equality or inequality search instruc¬ 
tion (SRCE or SRCN). 

2. Completion of a block move (MOVE instruction). 

Real-Time Clock Interrupt 

The Real-Time Clock interrupt is generated when the clock reaches a time 
previously stored in register 32 of the Register File. 


Input/Output Interrupts 

I/O Channel Interrupts 

Any of the eight possible I/O channels may be programmed to generate an inter¬ 
rupt for either of the following conditions: 

1. Reaching the end of an input or output block. 

2. Receiving an End of Record (Disconnect) signal from an external 
device. 

I/O Equipment Interrupt 

The I/O equipment interrupt is set when an interrupt signal is received from 
any of eight peripheral equipment controllers connected to any of the eight 
possible I/O channels (there may be a total of 64 interrupt lines). 

Associated Processor Interrupt 

In a system of two or more processors (computers), each processor may inter¬ 
rupt, or be interrupted by, one other processor by executing an lAPR (77. 57) 
instruction. This interrupt is not masked and becomes cleared as soon as it is 
recognized. 


Executive Interrupt 

The Executive Interrupt can only occur when the computer is operating in the 
Program State of Executive mode. An attempt to execute one of the following 
instructions then generates an Executive interrupt. 

1. Halt instruction (00. 0) 

2. Inter-register transfer instructions with the Register File locations 00 
through 37, [53. (4-7) (1-3) (XX00-XX37)J 
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3. Instructions with octal codes 71 through 77 except the 77. 71 SFPF and 
77. 72 SBCD instructions 

This interrupt is not masked and has priority over all of the internal condition 
interrupts. When the Executive interrupt has been recognized and the computer 
has reverted to the Monitor State, any of the instructions in the three categories 
above can be executed. 

Storage Parity Error—No Response Interrupt 

A Storage Parity Error interrupt has the highest priority of all interrupts and 
can occur if either a storage parity error is detected or if a storage module does 
not respond when referenced. The interrupt condition is recognized during the 
RNI and RADR sequence for an instruction. 

The PARITY INTERRUPT switch on the console must be active for the interrupt 
to occur. If the PARITY STOP switch is active, the computer stops when a 
parity error or no-response condition is detected. The two switches cannot be 
simultaneously active, and pressing the PARITY STOP switch overrides the 
Parity Interrupt condition. 

If Block Control has storage priority at the time of interrupt, the address of the 
next instruction to be executed is stored in the lower 15 bits of location 00020, 

The appropriate register file location contains the approximate address where 
the error occurred. An Interrupt during Main Control priority causes the address 
of the current Instruction to be stored in location 00020. If the error condition 
is detected during any of the RNI's for the BDP instructions, (P) is always stored 
at location 00020. Detecting the condition during either RNI for the 71-76 instruc 
tions results in either (p), (p + 1), or (P + 2) being stored. 

A code representing conditions within the processor at the time of interrupt is 
automatically stored in the lower 12 bits of location 00021. A RNI is then per¬ 
formed at location 00021. The stored address and code enable the interrupt 
routine to isolate the storage area where the error occurred and aid in program 
recovery. Table 4-0 lists the various codes and their interpretations. 

The instruction in progress when the interrupt is detected may be executed al¬ 
though the results are not necessarily correct. Once the parity error or no¬ 
response condition is detected, additional errors are not recognized until a DINT 
(77. 73) instruction is executed. 
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TABLE 4-0. PARITY ERROR INTERRUPT CODES 


Reason for Interrupt 

Type of Operation or 
Sequence in Progress 


Code 

No-Response 

Block Control - (73-76) 

00X0 

X = ch 

Parity Error 

Block Control - (73-76) 

00X2 

X = ch 

No-Response 

Block Control - 71, 72, or 

typewriter I/O 

01X0 

(X=0, Srch), 
(X=l, Move) , 
(X=3, TWR) 

Parity Error 

Block Control - 71, 72, or 

typewriter I/O 

01X2 

(X=0, Srch), 
(X=l, Move), 
(X=3, TWR) 

No-Response 

Main Control - RNI or RADR 

00X1 

(X=0, RNI) 
(X=2, RADR) 

Parity Error 

Main Control - RNI or RADR 

00X3 

(X=0, RNI) 
(X=2, RADR) 

No-Response 

Main Control - ROP or STO 

0005 


Parity Error 

Main Control - ROP or STO 

0007 



Illegal Write Interrupt 

This interrupt has priority over all interrupts except the Storage Parity Error 
interrupt. The interrupt condition may result during a RNI, RADR, ROP, or 
STO sequence; however it is recognized only during RNI or RADR, When the con¬ 
dition is recognized, the interrupt system is disabled, (P) are automatically 
stored at address 00014, and an RNI is performed at address 00015. 


The system must be in Program State of Executive mode to recognize the inter¬ 
rupt. The interrupt is disabled during Monitor State and during Search/Move and 
1/O cycles. The conditions for the interrupt are listed below. (Conditions 3 
through 6 apply only if the 3311 Multiprogramming Module is present in the sys¬ 
tem. ) 

1. A Write operation into an area protected by the Storage Protect 
switches (Program State 0). 

2. A Keyboard Write operation into the Executive Auto Load/Auto Dump 
area (addresses 03700 through 03777). 

3. A Read or Write operation when bits 9 and 10 of the original address 
specify a quarter page equal to or greater than PL, when PL 4 0. 

4. A Read or Write operation if the 'E' designator for any referenced 
index equals "l" and PA, PL, and PP are equal to zero. 

5. A Write operation if the 'E' designator for any referenced index equals 
”1" and PA, PL, or PP is not equal to zero, 

6 . A double precision instruction if the first operand is to be read from 
the last available memory location specified by PL, or if from the 
last memory location when PL specifies a full page and the next index 
to be used contains 4000. 
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Bit 05 of the internal status sensing network is set on an Illegal Write interrupt 
only if the condition occurred during a RNI or RADR sequence. If the condition 
occurred during a ROP or STO sequence, the interrupt is generated but bit 05 is 
not set. If one of the 66. 0 - 66.5 instructions is interrupted by an Illegal Write, 
the instruction always restarts at the beginning when the main program resumes. 
Other BDP instructions restart from the point of interrupt. 


Trapped Instruction Interrupts 

If an attempt is made to execute one of the instructions listed in Table 4-1 and 
the system is not equipped with a 3310 Floating Point module or 3312 BDP, the 
instruction becomes trapped. Only those instructions preceded by an asterisk 
(*) are trapped if the 3312 BDP is not present in the system and the 3310 Float¬ 
ing Point module is present. 


TABLE 4-1. TRAPPED INSTRUCTIONS FOR NON-EXECUTIVE 
MODE WITHOUT A 3310 OR 3312 MODULE IN SYSTEM 
(MNEMONIC LISTING) 


ELQ 

*MVE 

*SCAN,LR,NE, 

DC 

=s=UPAK 

EUA 

*MVE, DC 

>!<SCAN,RL,EQ 


'■‘ADM 

EAQ 

*MVBF 

*SCAN, RL, EQ, 

DC 

*SBM 

QEL 

*MVZF 

*SCAN,RL,NE 


*CMP 

AEU 

*MVZS 

*SCAN, RL, NE, 

DC 

* CMP, DC 

AQE 

*MVZS, DC 

>:<CVDB 


*TST 

MUAQ 

*ZADM 

*CVBD 


>!'JMP,HI 

DVAQ 

>:^FRMT 

*DTA 


*JMP,LOW 

FAD 

*EDIT 

*DTA,DC 


*JMP,ZRO 

FSB 

*SCAN,LR,EQ 

*ATD 


''i'SBR 

FMU 

*SCAN, LR,EQ,DC 

*ATD,DC 


>!=LBR 

FDV 

*SCAN,LR,NE 

-PAK 




Each instruction listed in Table 4-2 is processed as a no-Operation instruction, 
(refer to Section 5) if an attempt is made to execute one of them while operating 
in the non-Executive mode. ' 


TABLE 4-2. NO-OPERATION INSTRUCTIONS 
FOR NON-EXECUTIVE MODE 
(MNEMONIC LISTING) 


A Cl 

ISA 

ROS 

AIS 

JAA 

SBJP 

AOS 

OSA 

SDL 

APF 

PFA 

SRA 

CIA 

RCR 

TMAV 


RIS 
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Although they are not true interrupts, trapped instructions are processed like 
interrupts once they have been detected. A conventional interrupt always takes 
priority over a trapped sequence. 

The following operations take place when a trapped instruction is recognized: 

1. The address of the next sequential program step, P + 1, is stored in 
the lower 15 bits of address 00010. 

2. The upper 6 bits of the instruction in the F register are stored in the 
lower 6 bits of the operand stored at address 00011. The upper 18 
bits of this operand remain unchanged. 

3. Program execution commences at address 00011. 


EXAMPLE: MUAQ (56) Instruction execution attempt without the 

Floating Point/Double Precision hardware option in the 


Address 



At this point the MUAQ operation may be simulated 
by software and re-entry to the main program is 
possible by a jump to the contents of address 00010. 


Power Failure Interrupt 

If source power to the computer system fails, the power failure is detected and 
the computer program is interrupted. This interrupt is necessary to prepare a 
controlled shutdown and prevent the loss of data. The operation requires 16 ms 
for detection, and up to 4 ms for processing the special Power Failure interrupt 
routine. 

The Power Failure interrupt overrides any other interrupt except the Illegal 
Write and Storage Parity Error interrupts, regardless of the state of interrupt 
control. Since this interrupt overrides all others, the address where the pres¬ 
ent contents of P are stored and the address to which program control is trans¬ 
ferred must be different from that for a normal interrupt. When a Power 
Failure interrupt occurs, the machine stores the contents of P in the lower 15 
bits of address 00002 and transfers program control to address 00003. 

The normal interrupt system is disabled during a power failure sequence; i. e. , 
the hardware simulates the execution of a DINT (77. 73) instruction. 
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INTERRUPT CONTROL 


Through the use of certain instructions, a program can recognize, sense, and 
clear interrupts, and enable or disable the interrupt system. 


Enabling or Disabling Interrupt Control 


Instruction EINT (77. 74) enables the interrupt system and the DINT instruction 
(77. 73) disables it. After recognizing an interrupt and entering the interrupt 
sequence, other interrupts are disabled automatically. When leaving the interrupt 
subroutine, the interrupt system must again be enabled by the EINT instruction if 
interrupts that are waiting or subsequent interrupts are to be recognized by the 
system. Refer to the EINT (77. 74) instruction in Section 5 for special conditions 
regarding the actual interruption of the CPU. 


Interrupt Priority 

An order of priority exists between the various interrupt conditions. As soon as 
an interrupt becomes active, the computer scans the priority list until it reaches 
an interrupt that is active (not necessarily the interrupt that initiated the scanning). 
The computer processes this interrupt and the scanner returns to the top of the 
list where it waits for another active interrupt to appear. Table 4-3 lists the 
order of priority. 


TABLE 4-3. INTERRUPT PRIORITY 


PRIORITY 

TYPE OF INTERRUPT 

PRIORITY 

TYPE OF INTERRUPT 

1 

Storage Parity Error 

8 

BCD Fault 

2 

Illegal Write 

9-72 

I/O Equipment (External)* 

3 

Power Failure 

73-80 

I/O Channel** 

4 

Executive 

81 

Search/Move 

5 

Arithmetic Overflow 

82 

Real-time Clock 

6 

Divide Fault 

83 

Manual 

7 

Exponent Overflow/ 

84 

Associated Processor 


Underflow 

85 

Trapped Instruction 


* There are eight interrupt lines on each of the eight possible I/O channels, or 
64 lines in all. On any given channel, a lower numbered line has priority 
over a higher numbered line. Likewise, a lower numbered channel has 
priority over a higher numbered channel. Example: line 0 of channel 0 has 
highest priority of all external I/O interrupts, line 0 of channel 1 has second 
highest, and line 7 of channel 7 has the lowest. 

** A lower numbered I/O channel interrupt has priority over a higher numbered 
I/O channel interrupt. 
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Sensing Interrupts 

The programmer may selectively sense interrupts by using the INTS (77. 4) 
instruction. Sensing the presence of internal faults automatically clears them. 
Interrupt lines representing channels not present in the system are sensed as 
being active. The interrupt system need not be enabled for sensing. 


Clearing Interrupts 

Internal condition interrupts are cleared by: 

• Sensing with an INTS (77. 4) or ENTS (77. 3), after which interrupts are 
automatically cleared, 

• Executing an INCL (77. 50) instruction 

• Executing an lOCL (77. 51) instruction - clears only Search/Move inter¬ 
rupt, or 

• Pressing the MC or INTERNAL CLEAR buttons. 

I/O channel interrupts are cleared by: 

• Executing an INCL (77. 50), lOCL (77. 51), or CLCA (77. 512) instruction, 
or 

• Pressing the MC or EXTERNAL CLEAR buttons. 

I/O equipment interrupts are cleared by: 

• Executing an lOCL (77. 51) instruction, 

• Reselecting or releasing the interrupt with a SEL (77. 1) instruction, or, 

• Pressing the MC or EXTERNAL CLEAR buttons. 

The manual and associated processor interrupts are automatically cleared upon 
recognition by the computer. 


INTERRUPT PROCESSING 


Four conditions must be met before an Internal Condition, Executive, or I/O 
interrupt can be processed: 

1. A bit representing the interrupt condition must be set to "1" in the Inter¬ 
rupt Mask register (except for Manual, Associated Processor, and 
Executive interrupts) . 

2. The interrupt system must have been enabled (except for Executive Inter¬ 
rupt) . 

3. An interrupt-causing condition must exist. 
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4. The interrupt scanning logic (Refer to Table 4-3) must reach the 
level of the active interrupt on the priority list. 

When an active interrupt has met the above conditions, the following takes 
place: 

1. The instruction in progress proceeds until the point is reached in the 
RNI or RADR cycle where an interrupt can be recognized. At this time 
the count in P has not been advanced nor has any operation been initiated. 
When an interrupt is recognized, the address of the current unexecuted 
instruction in P is stored in address 00004. 

2. A number representing the interrupt-causing condition is stored in the 
lower 12 bits of address 00005 without modifying the upper bits. Table 
4-4 lists the octal codes which are stored for each interrupt condition. 

3. Program control is transferred to address 00005 and an RNI cycle is 
executed. 


TABLE 4-4. REPRESENTATIVE INTERRUPT CODES 


Conditions 

Codes 

External interrupt 

*00LCh 

I/O channel interrupt 

OlOCh 

Real-Time Clock interrupt 

0110 

Arithmetic overflow fault 

0111 

Divide fault 

0112 

Exponent overflow fault 

0113 

BCD fault 

0114 

Search/move interrupt 

0115 

Manual interrupt 

0116 

Associated processor interrupt 

0117 

Executive Interrupt 

0120 


*L = line 0-7 and Ch = channel designator, 0-7 


INTERRUPT MASK REGISTER 


The programmer can choose to honor or ignore an interrupt by means of the 
Interrupt Mask register. All but three of the normal interrupt conditions are 
represented by the 12 Interrupt Mask register bits. The Manual, Associated 
Processor and Executive interrupts are not masked. The mask is selectively 
set with the SSIM (77. 52) instruction and selectively cleared by the SCIM (77. 53) 
instruction. See Table 4-5 for Interrupt Mask register bit assignments. 

The contents of the Interrupt Mask register may be transferred to the upper 12 
bits of the A register for programming purposes with the COPY (77. 2) or CINS 
(77. 3) instructions. 
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TABLE 4-5. INTERRUPT MASK REGISTER BIT ASSIGNMENTS 


Mask Bits 

Mask Codes 

Interrupt Conditions Represented 

00 

0001 

I/O Channel 0^ 


01 

0002 

1 


02 

0004 

2 

(Includes interrupts 

03 

0010 

3 

04 

0020 

4 

r generated within the 

05 

0040 

5 

channel and external 

06 

0100 

6 

equipment interrupts. ) 

07 

0200 

7, 


08 

0400 

Real-time clock 

09 

1000 

Exponent overflow/underflow and BCD 
faults 

10 

2000 

Arithmetic overflow and divide faults 

11 

4000 

Search/Move completion 


INTERRUPTS DURING EXECUTIVE MODE 


Although all interrupts can be recognized during Executive mode, special 
consideration must be given to handling these interrupts. During Executive 
mode, the Condition register records current operating information that must 
temporarily be stored in the event of interrupt to enable proper recovery. 
Table 4-6 lists the Condition register bit assignments. 


TABLE 4-6, CONDITION REGISTER BIT ASSIGNMENTS 


Bit 

Condition 

Represented 

00 

Boundary Jump 

Set by SBJP (77. 62) instruction. 

Cleared by next jump instruction. 

01 

Destructive Load A - 

Set by SDL (77. 624) instruction. 

Cleared by next LDA instruction. 

02 

Operands Relocated - 
Using OSR 

Set by ROS (55. 4) instruction. 

Cleared by RIS (55. 0) instruction. 

03 

Program State Jump- 

Set by any jump during Program State. 
Cleared when jumping to Program State. 

04 

Interrupt System 
Enabled 

Set by EINT (77. 74) instruction. 

Cleared by DINT (77. 73) instruction. 

05 

Program State 

Set when jiomping to Program State. 


To insure the processing of stacked interrupts, it is necessary to transfer these 
conditions to the A register at the start of the interrupt routine by executing a 
CRA (77, 63) instruction. At the completion of the interrupt routine, these 
conditions must be restored by executing a ACR (77. 634) instruction. 
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Upon interrupt recognition, the interrupt system is automatically disabled and 
the Central Processor enters the Monitor State. The Condition register and all 
interrupts, except Trapped Instruction interrupts, are disabled during the inter¬ 
vals between interrupt recognition and CRA instruction execution, and between 
execution of the ACR instruction and the jump instruction normally used to exit 
from an interrupt routine. 

The Condition register is cleared as the transfer to A is completed; the interrupt 
system remains disabled until a EINT (77. 74) or ACR instruction is executed. 
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5. INSTRUCTIONS 


GENERAL INFORMATION 


A 3300 machine coded instruction word is 24 bits in length and may require up 
to three sequential words for a particular function. Although there are 24 dis¬ 
tinct instruction formats, as illustrated in Appendix D, there are several that 
are used more frequently than others. These formats (word oriented, character 
oriented, and business oriented) are shown in the following pages along with 
their appropriate instruction parameters. 


Instruction Parameters 


The following parameters are used in the 3300 instruction list. A capitalized 
letter generally indicates a modified parameter, however, this is not always 
the case and the specific instruction should be consulted. Some parameters are 
general in nature, i.e., specifying a character address, but in some instances 
may indicate a high order address and in others a low order address. The 
parameter descriptions listed below each instruction format should be checked 
for the explicit memory of the parameters for that particular instruction. 


If an octal number appears in the format of a specific instruction, only that 
number must be placed in the exact position as indicated. In cases where only 
a single binary position is involved, a "1" or ''0" is used depending upon the 
instruction. The following parameters are used throughout the 3300 instruction 
list: 


A 


a 

B 

b 


(1) variable length field of characters designated field A 
in BDP instructions; usually the transmitting field. 

(2) A is used in the descriptions for instructions (other 
than those for BDP) to indicate the A register. 

addressing mode (a = ”0" for direct addressing, a = "1" 
for indirect addressing) 

"1” for backward storage 

index register designator 1, 2, or 3. 
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B 


m 


B 


n 


B 


r 


Bs 


C 

ch 

DC 


G 

H 

INT 

I 

i 

j 

k 

K 

S 

^2 


index register flag for a field in certain BDP instructions. 
The flag indicates which index register will have its con¬ 
tents added to the unmodified address 'm'. M = m + [ B^^] 
for these instructions only. 

index register flag for a field in certain BDP instructions 
where both fields are specified by word addresses. The 
flag indicates which index register will have its contents 
added to the unmodified address 'n'. 

index register flag for field A in most BDP instructions 
(refer to individual instruction descriptions). Initial 
character address of field A is defined; R = r + [ B^,] . If 
Bj, = 1 or 3, use (B^); if Bj, = 2, use (B^); if Bp = 0, no 
indexing is performed and R = r. 

index register flag for field C in most BDP instructions 
(refer to individual instruction descriptions). Initial 
character address of field C is defined; S = s + [ Bg] . 

If Bg = 1 or 3 use (B^); if B g = 2, use (B^); if Bg =0, no 
indexing is performed and S = s. 

variable length field of characters designated field C in 
BDP instructions. Usually the receiving field. 

denotes I/O channel (0 through 7). 

indicates delimiting character position within the instruction 
word or mnemonic. Generally, a delimiting character of 6 
or 8 bits is specified in an instruction and if a character is 
recognized, during the particular operation, that equals the 
delimiting character, the operation is terminated. 

"l" for word count control with the INPC and INPW instruc¬ 
tions. 

indicates special Assembly/Disassembly operation in 
certain character oriented I/O instructions. 

"l" for interrupt upon completion in certain I/O instructions. 

assembly language designator indicating indirect addressing. 

internal parameter (decrement or increment). 

Jump designator. 

(1) unmodified shift count for SHA,SHQ, and SHAQ 
instructions. 

(2) scale factor for SCAQ instruction. 

(1) modified shift count, K = k + (B^) for SHA,SHQ, 
and SHAQ instructions. 

(2) residue quantity for SCAQ instruction. 

field length of data block for MOVE instruction, 
number of characters in BDP field A (character count), 
number of characters in BDP field C (character count). 
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m 

M 

n 

N 

r 

R 


s 

S 


SC 

V 

w 

X 

y 

z 

////// 


unmodified 15-bit storage word address. 

modified 15-bit storage address, M = m + (B^). 

same as 'm', but the word address of the second operand 
for certain I/O instructions, 

indicates special Assembly/Disassembly operation in 
certain word oriented I/O instructions. 

unmodified 17-bit character address. 

modified 17-bit character address; 

R = r + (B^) for BDP instructions, (Refer also to 'Bj.'.) 

R = r + (Bb) for all other instructions, 

same as 'r', but the character address of the second oper¬ 
and for certain I/O instructions, 

(1) modified 17-bit character address of field C for BDP 
instructions only, S = s + (Bg), (Refer also to 'Bg',) 

(2) also used to denote sign extension for certain instruc¬ 
tions. 

6- bit comparison scan character used in search instructions. 
May be used with DC. 

a specific register number (00-77) within the Register 
File. 

7- bit Page Index File address, (Refer to APF and PFA 
instructions and Appendix E for additional information.) 

connect code or interrupt mask. 

15-bit operand 

17-bit operand 

slashing indicates a particular area of an instruction that 
should be loaded with zeros although the particular area is 
not used for the instruction. 


In addition to the instruction parameters, various abbreviations are used in the 
instruction descriptions that refer to various registers and operations. These 
abbreviations and their literal meanings are listed here: 


ISR 

= Instruction State register 


OSR 

= Operand State register 


CIR 

= Channel Index register 


CR 

= Condition register 


BCR 

= BDP Condition register 


PIF 

= Page Index File 


(AoQ-02) 

= contents of the lower 3 bits (00, 01, and 02) 

of the A register 

[Brl 

= contents of the index register as defined by 

Br flag. 

the value of the 
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in "less than" n 
m "greater than" n 
m "greater than or equal to" n 
logical product of m and n 
contents of m, transferred to n 
Exclusive OR function 
AND function 

Instruction Word Formats 

Word oriented instructions are the most common of the instruction formats. 
Fifteen bits are allocated for an unmodified storage address, operand, or shift 
count. Indirect addressing is usually available. Figure 5-1 illustrates a word 
oriented instruction and the significance of the first 15 bits when they represent 
an unmodified word address 'm'. 


m<n 

m>n 

m>n 

m*n 

(m)-^n 

V 


i 


BITS-* 23 18 17 16 15 14 00 


(6 BITS} 

(1 BIT) 

(2 BITS) 

(15 BITS) 

\ / 

\ /\ / 

\___ ! 

V 

V 


V 

FUNCTION CODE 

0 

b 

m 


j k 

y 


Symbol designators 
(See Symbol Definitions) 

Figure 5-1. Word-Addressed Instruction Format 

Character oriented instructions allocate 17 bits for unmodified character ad¬ 
dresses or extended operands. Indirect addressing is not available for these 
instructions; however, address modification is permissible by referencing a 
specific index register. Figure 5-2 illustrates the format of a character 
oriented instruction word and the significance of the first 17 bits when they re¬ 
present an unmodified character address 'r'. 


23 18 17 16 00 


(6 BITS ) 

(1 BIT) 

( 17 BITS ) 

\_ l\ _ l\ _ . . J 

V 

y 

V 

FUNCTION CODE 

b 

r 


Z 


Characters in a data word are always specified in the following manner; 

23 _ 18 17 _ 12 II _ 06 05 _00 

0 12 3 

character designators 

Figure 5-2. Character-Addressed Instruction Format 
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Word Addressing/Character Addressing 

It is often desirable to convert a word address and character position to its 
corresponding character address or vice versa. The following procedure is a 
technique used for this purpose. 

To convert a word address to a character address: 

• Octally multiply the word address by four, (During program execution, 
this operation is simulated by a left shift of two binary places,) 

• Add the character position to the product. 

The sum is the character address. 


EXAMPLE: 

Given: Word address 12442, character position 2 

Find: Corresponding character address 

1, 12442 

_ ^ 

52210 

2 . +2 

52212 = character address 

To convert a character address to a word address: 

• Octally divide the character address by four 

The quotient is the word address and the remainder is the character position. 
No remainder indicates character zero, 

EXAMPLE: 

Given: Character address 03442 

Find: Word address and character position 

00710 

^03442 

M 

4 

j4 

2 = remainder = character position 2 

NOTE 

Octal multiplication and division tables may be found in 
Appendix C of this manual. 

Instruction word formats that differ from word and charac¬ 
ter orientation are described in the instruction listing. 

Business oriented instructions require three instruction words to completely 
define an operation. These instructions are executed only by the BDP, These 
subinstruction words are always located at consecutive memory locations, 
nominally designated P, P+1, and P+2. 
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"l” FOR DELIMITING WHEN AVAILABLE 


P 


P+ I 


P+ 2 




23 


8 

17 

16 



00 

(6 BITS) 

(1 BIT) 

(17 BITS ) 

\ 



\ 



/ 

-V- 

FUNCTION CODE 





V 

r OR m (15 BITS) 


23 21 

20 19 

18 

17 

16 



00 

(3 BITS) 

(2 BITS) 


BITS) 

(17 BITS) 

\ / 

\ / 

\ 

/ 

V 



/ 

V 

SUB -FCN 
CODE 

Bf OR Bm BsOR Bn 


V 

S OR m OR n (15 BITS) 


23 





12 

11 

00 



\_ 





_ l\ _ 

_/ 



Figure 5-3. Business Oriented Instruction Format 


Indexing and Address Modification 

In some instructions, the execution address 'm' or 'r', or the shift count 'k' 
may be modified by adding to them the contents of an index register, B^. The 
2-bit designator 'b' specifies which of the three index registers is to be used. 
Symbols representing the respective modified quantities are M, R, and K. 

M = m + (B^*) 

R = r + (B^) the sign of B^ is extended to bit 16 
K = k + (B^) 

In each case, if b = 0, then M = m, R = r and K = k. 
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Special index considerations apply to BDP instructions where an index register 
flag is present. A flag defines which index register is used for indexing: 

EXAMPLE: 

If s = 00413, Bs = 2, and (B^ = 00364, then S = s + [ Bg] or "the 
modified address 'S' equals the unmodified address 's' added to the 
contents of the index register as defined by Bg". 

Thus: 

S = s + [Bg] 

S = 00413 + (b2) 

S = 00413 + 00364 
S = 00777 

Some BDP instructions, i.e. , PAK, CVBD, DTA, etc. utilize both word and 
character addresses in their formats. Although the first two bits preceding the 
address are unused and not part of the word address, the lower 15 bits of this 
word are added to the contents of the specified index register. The lower two 
bits of the specified index register must be set to "I's" to allow for an end- 
around carry during the index addition. 


EXAMPLE: 


16 15 t4 


oa 0100 

1 

1 

n 


m 

t 

1 

1 

\ 



1 

1 

1 

_/ 


tB^] are added to 
the first 15 bits 


Addressing Modes 

Three modes of addressing are used in the computer: No Address, Direct Ad¬ 
dress, and Indirect Address. 

No Address 

This mode is used when an operand 'y' or a shift count 'k' is placed directly in¬ 
to the lower portion of an instruction word. Symbols 'a' and 'b' are not used as 
addressing mode and index designators with any of the no address instructions. 

Direct Address 

The direct addressing mode is used in any instruction in which an operand ad¬ 
dress 'm' is stored in the lower portion of the initial instruction word. This 
mode is specified by making 'a' equal to 0. In many instructions, address 'm' 
may be modified (indexed) by adding to it the contents of register b'^, M = m + 
(Bb). 
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Indirect Address 

It is possible to use indirect addressing only with instructions that require an 
execution address 'm'. For applicable instructions, indirect addressing is 
specified by making 'a' equal to 1. Several levels (or steps) of indirect addres¬ 
sing may be used to reach the execution address; however, execution time is 
delayed in direct proportion to the number of steps. The search for a final ex¬ 
ecution address continues until 'a' equals 0. It is important to note that direct 
or indirect addressing and address modification are two distinct and indepen¬ 
dent steps. In any particular instruction, one may be specified without the 
other. Figure 5-4 shows the indirect addressing routine. 



Figure 5-4. Indexing and Indirect Addressing Routine Flow Chart 

NOTE 

Unless it is otherwise stated, indirect addressing follows the 
above routine throughout the list of instructions. 
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Indexing and Indirect Addressing Examples 

The following examples utilize the LDA (20) instruction; however, the process 
applies to any of the instructions with an 'a' and/or 'b' designator. 


EXAMPLE 1: 


(ADDRESS MODIFICATION - (indexing) ONLY) 


00000 20 2 54430 

t 

Indicates Direct Address 
mode and address modification 
by b2 


(b2) = 13342 


I V P 

s Direct Address Add this address to (B ) 

:d address modification ^ 

54430 

+13342 

20 2 67772<—Thig address is replaced^—67772 
temporarily in the 
original instruction 


LDA with the 24-bit quantity stored at address 67772 
67771 - 

P = 67772 77700000-^This quantity is loaded into the A register 

67773 -.. 


EXAMPLE 2: 


(INDIRECT ADDRESSING ONLY) 


P = 00001 20 4 

Indicates Indirect Addressing Go to this address and acquire 

mode but no address modification new address and designator be- 



This portion of operand is replaced temporarily 
in the original instruction. 



T 


Indicates Direct Address mode and no address modification. LDA 



with the 24-bit operand stored at address 77111. (If this digit would 
have indicated additional indirect addressing and/or address modifi¬ 
cation this must be done before the LDA instruction is executed. ) 
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EXAMPLE 3: 


(INDIRECT ADDRESSING AND ADDRESS MODIFICATION) 


I- 

P = 00002 20 

t 

Indicates Indirect Address 
mode and address modifica¬ 
tion by b1 . 


(B^) = 00512 

V 

Add this address to (B^). 

54430 

+00512 

55142 

t 

Go to this address and 
acquire new address 
and designator before 
executing instruction. 


55141 - 

^55142 77'03 7777, 

55143 


This portion of operand is replaced temporarily in 
the original instruction. 

t - ^ -V 

20^37777 

t 

Indicates direct address mode and no address modi¬ 
fication, LDA with the 24-bit operand stored at ad¬ 
dress 3 7777. (If this digit would have indicated ad¬ 
ditional indirect addressing and/or address modifi¬ 
cation, this must be done before the LDA instruc¬ 
tion is executed.) 
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Trapped Instructions 


Certain instructions are trapped if the optional hardware module, necessary 
for their direct execution, is not present in the system. These instructions, 
and the routine followed in processing trapped instructions, are described in 
Section 4. 


INSTRUCTION LIST 


Each group of instructions is introduced with an index, and whenever necessary, 
a group description. Individual instructions are all presented in the same basic 
format: 

• Heading, which includes the assembly language mnemonic and 
instruction name or function. 

• Machine code instruction format. 

• Parameters and their descriptions. 

• Instruction description. 

• Comments (when necessary). 

The instructions are grouped into general functions, i. e. . Loads, Stores, 
Arithmetic, etc., and the groups are arranged according to the complexity of 
their functions. This arrangement permits a programmer, unfamiliar with the 
instruction list, to progress through this Section with relative ease. 

The abbreviation, RNI, is used throughout the list of instructions to indicate 
the Read Next Instruction sequence. This is a sequence of steps taken by the 
control section to advance the computer to its next program step. For an ex¬ 
tensive description of this sequence, consult the 3 300 Customer Engineering 
Manual. 

Table 5-1 identifies the instructions by mnemonic and indicates on which page 
detailed instruction descriptions may be found.''' Table 5-2 is a summary of the 
instruction execution times. In addition to these tables, additional tables are 
provided at the end of this manual for cross reference of the instruction list. 


The letter "l" after a mnemonic code in Table 5-1 as well as in each group of 
instructions, and in the mnemonic and octal listings in the last section of this 
manual, indicates that indirect addressing may be used for that instruction. 


5-11 


Rev. A 



TABLE 5-1, INSTRUCTION SYNOPSIS AND INDEX 


Mnemonic 

Instruction 

Page No. 

ACI 

Transmit (A) to CIR 




5-38 

ACR 

Transmit (A) to CR 




5-40 

ADA, I 

Add to A 




5-60 

ADAQ, I 

Add to AQ 




5-61 

ADM 

Add field A to field C 




5-68 

AEU 

Transmit (A) to Ep 




5-36 

AIA 

Transmit (A) + (B^) to 

A 


5-33 

AIS 

Transmit (A) to ISR 




5-37 

ANA 

Logical product (AND) 

of y and (A) 


5-73 

ANA, S 

Logical product (AND) 
tended 

of y and (A) , sign ex- 

5-73 

ANI 

Logical product (AND) 

of y and (B°) 


5-73 

ANO 

Logical product (AND) 

of y and (Q) 


5-74 

ANQ, S 

Logical product (AND) 
tended 

of y and (Q) , sign ex- 

5-74 

AOS 

Transmit (A) to OSR 




5-37 

APF 

Transmit (Agg-il) to PIF 


5-39 

AQA 

Transmit (A) + (Q) to A 


5-32 

AQE 

AQJ, EQ 

Transmit (AQ) to E 

r- 

jump if (A) = Q 


5-36 

AQJ, NE 

Compare A with Q < 


jump if (A) 4 Q 

> 

5-46 

AQJ, GE 



jump if (A) > Q 



AQJ, LT 



jump if (A) < Q 



ASE 

Skip next instruction, 

if (A) = y 


5-29 

ASE, S 

Skip next instruction if (A) = y, sign extended 

5-29 

ASG 

Skip next instruction if (A) > y 


5-30 

ASG, S 

Skip next instruction if (A) > y, sign extended 

5-30 

ATD 

Translate ASCII to BCD 


5-119 

ATD, DC 

Translate ASCII to BCD, delimiting character 
possibility 

5-120 

AZJ, EQ 



"^jump if (A) = 0 



AZJ, NE 

AZJ, GE 

Compare A with zero< 

jump it (A) 4 0 

jump if (A) > 0 

> 

5-45 

AZJ, LT 

_ 



jump if (A) < Q^ 
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TABLE 5-L INSTRUCTION SYNOPSIS AND INDEX (Cont'd) 


Mnemonic 

Instruction 

Page No. 

CIA 

Transmit (CIR) to A 

5-38 

CILO 

Channel interrupt lockout 

5-91 

CINS 

Copy internal status 

5-86 

CLCA 

Clear channel activity 

5-94 

CMP 

Compare field A with field C, exit if 

5-79 

CMP, DC 

Compare field A with field C, exit if f, delimit¬ 
ing character possibility 

5-80 

CON 

Connect 

5-95 

COPY 

Copy external status 

5-83 

CPR, I 

Within limits test 

5-77 

CRA 

Transmit ( CR) to A 

5-40 

CTI 

Set console typewriter input 

5-97 

CTO 

Set console typewriter output 

5-97 

CVBD 

Convert binary to BCD 

5-116 

CVDB 

Convert BCD to binary 

5-115 

DINT 

Disable interrupt control 

5-89 

DTA 

Translate BCD to ASCII 

5-117 

DTA, DC 

Translate BCD to ASCII, delimiting character 


possibility ■ ' 

5-118 

DVA, I 

Divide AQ (48 by 24) 

5-62 

DVAQ, I 

Divide AQE (96 by 48) 

5-63 

EAQ 

Transmit (E-y) to A and (Ej^) to Q 

5-36 

ECHA 

Enter A with 17 bit character address 

5-26 

ECHA, S 

Enter A with 17 bit character address, sign 
extended 

5-26 

EDIT 

Edit field A, move to field C 

5-149 

EINT 

Enable interrupt control 

5-89 

ELQ 

Transmit (E]_^) to Q 

5-36 

ENA 

Enter A 

5-25 

ENA, S 

Enter A, sign extended 

5-25 

ENI 

Enter index 

5-25 

ENQ 

Enter Q 

5-25 

ENQ, S 

Enter Q, sign extended 

5-25 

EUA 

Transmit (Ey) to A 

5-36 

EXS 

Sense external status 
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TABLE 5-1, INSTRUCTION SYNOPSIS AND INDEX (Cont'd) 


Mnemonic 

Instruction 

FAD, I 

Floating add to AQ 

FDV, I 

Floating divide AQ 

EMU, I 

Floating multiply AQ 

FRMT 

Formatted edit of field A, move to field C 

FSB, I 

Floating subtract from AQ 

HLT 

Unconditional halt; read next instruction from 
location m 

lAI 

Transmit (B^) + (A) to B^ 

lAPR 

Interrupt associated processor 

IJD 

Index jump; decrement index 

IJI 

Index jump; increment index 

INA 

Increase A 

INA, S 

Increase A, sign extended 

INAC, INT 

Character-addressed input to A 

INAW, INT 

Word-addressed input to A 

INCL 

Clear interrupt 

INI 

Increase index 

INPC,INT,BJI,G 

Character-addressed input to storage 

INPW,INT,B,N,G 

Word-addressed input to storage 

INQ 

Increase Q 

INQ, S 

Increase Q, sign extended 

INS 

Sense internal status 

INTS 

Sense interrupt 

lOCL 

Clear I/O, typewriter, and S/M 

ISA 

Transmit (ISR) to A 

ISD 

Index skip; decrement index 

ISE 

Skip next instruction if y = 0 

ISE 

Skip next instruction if (B^) = y 

ISG 

Skip next instruction if y > 0 

ISG 

Skip next instruction if (B^) > y 

ISI 

Index skip; increment index 


Page No. 



5-24 

5-33 

5-113 

5-44 

5-43 

5-27 

5-27 

5-106 

5-107 

5-89 

5-27 

5-98 

5-100 

5-27 

5-27 

5-85 

5-84 

5-94 

5-37 

5-31 

5-28 

5-28 

5-30 

5-30 

5-31 
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TABLE 5-1. INSTRUCTION SYNOPSIS AND INDEX (Cont'd) 


Mnemonic 

Instruction 


JAA 

Transmit jump address to A 


5-40 

JMP, HI 

Jump if BDP register > 0 or + 



JMP, ZRO 

Jump if BDP register = 0 

> 

5-42 

JMP, LOW 

Jump if BDP register < 0 or - , 



LACH 

Load A character 


5-49 

LBR 

Load BDP Condition register 


5-155 

LCA, I 

Load A complement 


5-50 

LCAQ, I 

Load AQ complement (double precision) 

5-51 

LDA, I 

Load A 


5-49 

LDAQ, I 

Load AQ (double precision) 


5-50 

LDI, I 

Lohd index 


5-52 

LDL, I 

Load logical 


5-50 

LDQ, I 

Load Q 


5-51 

LPA, I 

Logical product with A 


5-73 

LQCH 

Load Q character 


5-52 

MEQ 

Masked equality search 


5-75 

MOVE,INT 

Move (S) characters from r to s 


5-138 

MTH 

Masked threshold search 


5-76 

MUA, I 

Multiply A 


5-62 

MUAQ, I 

Multiply AQ 


5-63 

MVBF 

Move and blank fill 


5-142 

MVE 

Move 


5-140 

MVE, DC 

Move, delimiting character possibility 

5-141 

MVZF 

Move and zero fill 


5-143 

MVZS 

Move and zero suppress 


5-144 

MVZS. DC 

Move and zero suppress, delimiting character 
possibility 

5-145 

OSA 

Transmit (OSR) to A 


5-37 

OTAC, INT 

Character-addressed output from A 

5-109 

OTAW, INT 

Word-addressed output from A 


5-110 

OUTC, INT, B, H 

Character-addressed output from storage 

5-102 

OUTW, INT, B,N 

Word-addressed output from storage 

5-104 

PAK 

Pack 6 bit BCD characters into 4 bit BCD 
characters 

5-121 
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TABLE 5-1. INSTRUCTION SYNOPSIS AND INDEX (Cont'd) 


Mnemonic 

Instruction 

Page No. 

PAUS 

Pause 


5-87 

PFA 

Transmit (PFI) to A 

5-39 

PRP 

Priority pause 

5-88 

QEL 

Transmit (Q) to Ej^ 

5-36 

QSE 

Skip next instruction if (Q) = y 

5-29 

QSE, S 

Skip next 

instruction if (Q) = y, sign 

extended 

5-29 

QSG 

Skip next 

instruction if (Q) > y 

5-30 

QSG, S 

Skip next 

instruction if (Q) > y, sign 

extended 

5-30 

RAD, I 

Replace add 

5-60 

RIS 

Relocate 

to instruction state 

5-112 

ROS 

Relocate to operand state 

5-112 

RTJ 

Return jump 

5-47 

SACK 

Store character from A 

5-54 

SBA, I 

Subtract from A 

5-61 

SBAQ, I 

Subtract from AQ 

5-61 

SB CD 

Set BCD fault 

5-91 

SBJP 

Set boundary jump 

5-112 

SBM 

Subtract field A from field C 

5-69 

SBR 

Store BDP Condition register 

5-155 

SCA, I 

Selectively complement A 

5-72 

SCAN, LR, EQ, DC 


left to right, stop on = ' 


5-130 

SCAN, LR, NE, DC 


stop on f 


5-132 




Delimiting 





r character 


SCAN, RL, EQ, DC 


right to left, stop on = 

possibility 

5-134 

SCAN, RL, NE, DC 


stop on ^ 


5-136 

SCAN, LR, EQ 


left to right, stop on = 

5-129 

SCAN, LR, NE 


stop on f 

5-131 


Scan 



SCAN, RL, EQ 


right to left, stop on = 

5-133 

SCAN, RL, NE 


stop on / 

5-135 

SCAQ 

Scale AQ 


5-59 
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TABLE 5-1. INSTRUCTION SYNOPSIS AND INDEX (Cont'd) 


Mnemonic 

.. 

Instruction 

..—- 1 

Page No. 

SCHA, I 

Store 17-bit character address from A 

5-56 

SCIM 

Selectively clear interrupt mask 

5-90 

SDL 

Set destructive load 

5-113 

SEL 

Select function 

5-96 

SFPF 

Set floating point fault 

5-91 

SHA 

Shift A 

5-57 

SHAQ 

Shift AQ 

5-59 

SHQ 

Shift Q 

5-59 

SJl 

Jump if key 1 is set 

5-41 

SJ2 

Jump if key 2 is set 

5-41 

SJ3 

Jump if key 3 is set 

5-41 

SJ4 

Jump if key 4 is set 

5-41 

SJ5 

Jump if key 5 is set 

5-41 

SJ6 

Jump if key 6 is set 

5-41 

SLS 

Selective stop 

5-24 

SQCH 

Store character from Q 

5-55 

SRCE, INT 

Search character equality 

5-125 

SRCN, INT 

Search character inequality 

5-127 

SSA, I 

Selectively set A 

5-72 

SSH 

Storage shift 

5-57.■: 

SSIM 

Selectively set interrupt mask 

5-90 

ST A, I 

Store A 

5-53 

STAQ, I 

Store AQ 

5-54 

STI, I 

Store index 

5-56 

STQ, I 

Store Q 

5-5 5 

SWA, I 

Store 15-bit word address from A 

5-56 

TAI 

Transmit (A) to 

5-33 

TAM 

Transmit (A) to high speed memory 

5-34 

TIA 

Transmit (B^) to A 

5-33 

TIM 

Transmit (B^) to high speed memory 

5-35 

TMA 

Transmit (high speed memory) to A 

5-34 
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TABLE 5-1. INSTRUCTION SYNOPSIS AND INDEX (Coni'd) 


Mnemonic 

Instruction 

Page No. 

TMAV 

Test memory availability 

5-81 

TMI 

Transmit (high speed memory) to 

5-35 

TMQ 

Transmit (high speed memory) to Q 

5-34 

TQM 

Transmit (Q) to high speed memory 

5-34 

TST 

Test field A for+, -, 0 

5-82 

TSTN 

Test field A for numeric 

5-82. 0 

UCS 

Unconditional Stop 

5-24 

UJP, I 

Unconditional Jump 

5-41 

UPAK 

Unpack 4 bit BCD characters into 6 bit BCD 
characters 

5-122 

XOA 

Exclusive OR y and (A) 


XOA, S 

Exclusive OR y and (A) , sign extended 


XOI 

Exclusive OR y and (B^) 

5-71 

XOQ 

Exclusive OR y and (Q) 


XOQ, S 

Exclusive OR y and (Q) , sign extended 


ZADM 

Zero and add 

5- 146 


No-Operation Instructions 


When an attempt is made to execute one of the following instructions at the 
current execution address, P, the computer recognizes them as No-Operation 
(NO-OP) instructions and advances to the next execution address, P + 1. In 
mnemonics a No-Operation instruction is written as; NOP. 


NO-OPE R ATION 
OCTAL CODES 


02 

0 

14 

0 

15 

0 

16 

0 

17 

0 


During non-Executive mode operation each of the following instructions are re¬ 
cognized as No-Operation instructions if an attempt is made to execute one of 
them. Also refer to Trapped Instruction processing, Section 4. 


ACI 

ISA 

ROS 

AIS 

JAA 

SBJP 

AOS 

OSA 

SDL 

APE 

PEA 

SRA 

CIA 

RCR 

RIS 

TMAV 
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Instruction Execution Times 


Except for the 64.0 through 77. 1 instructions, an actual instruction execution 
time consists of the base execution time listed plus the time for an RNI cycle. 

If indexing or indirect addressing is used, their execution times must be added 
to base instruction time. 

Relocation time is added only if the RNI or RADR cycle preceding the RNI or 
RADR currently in progress was in a different memory page or if the ROP or STO 
cycle preceding the ROP or STO in progress was in a different memory page. 

That is, by programming RNI's and RADR's in the same page and ROP's and 
STO's in the same page, relocation processing time can be minimized. 

Table 5-2 is an octal list of all 3300 instructions with their base execution 
times. During certain multiple cycle instructions, it is possible to execute 
other instructions concurrently, thus no additional execution time is required. 


TABLE 5-2. SUMMARY OF INSTRUCTION EXECUTION TIMES, USEC 


Instruction 

Processing Operation 

Time Added to Base 

Execution Time (usee) 

RNI cycle 

1^ 

Indexing (address modi- 


fication) 

.375 

Relocation 

.250* 

Indirect addressing 

1,375 


*The time added to base execution time is 0. 150 usee if the Multiprogramming 
Module is present and no relocation is performed. 


<7 
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TABLE 5-2 (Cont'd) 


Basic 

Octal 

Code 

Mnemonic 

Code 

Execution 

Time 

(usee) 

Basic 

Octal 

Code 

Mnemon ic 
Code 

Execution 

Time 

(usee) 

00 

HLT 

0. 000 

17 

ANI 

0. 000 

00 

SJl-6 

0. 000 

17 

ANA 

0. 000 

00 

RTJ 

1. 375 

17 

ANQ 

0. 000 

01 

UJP 

0. 000 

20 

LDA 

1. 375 

02 

IJI 

0. 000 

21 

LDQ 

1. 375 

02 

IJD 

0. 000 

22 

LACK 

1.375 

03 

AZJ 

0. 625 

23 

LQCH 

1. 375 

03 

AQJ 

0. 625 

24 

LCA 

1. 375 

04 

ISE 

0. 625 

25 

LDAQ 

2. 625 

04 

ASE 

0. 625 

26 

LCAQ 

2. 625 

04 

QSE 

0. 625 

27 

LDL 

1. 375 

05 

ISG 

0. 625 

30 

ADA 

1. 375 

05 

ASG 

0. 625 

31 

SBA 

1. 375 

05 

QSG 

0. 625 

32 

ADAQ 

2. 625 

06 

MEQ 

2. 3 7 5 + 2. 5n 

33 

SBAQ 

2. 625 

07 

MTH 

2.375 + 2.5n 

34 

RAD 

2. 625 

10 

SSH 

2. 625 

35 

SSA 

1. 375 

10 

ISI 

0. 625 

36 

SCA 

1. 375 

10 

ISD 

0. 625 

37 

LPA 

1. 375 

11 

ECHA 

0. 000 

40 

STA 

1. 375 

12 

SHA 

0. 000 to 1.375 

41 

STQ 

1. 375 

12 

SHQ 

0. 000 to 1.375 

42 

SACK 

1. 375 

13 

SHAQ 

0. 000 to 1. 375 

43 

SQCH 

1. 375 

13 

SCAQ 

0. 875 to 2. 250 

44 

SWA 

1. 375 

14 

ENI 

0.000 ■ 

45 

STAQ 

2. 625 

14 

ENA 

0. 000 

46 

SCHA 

1. 375 

14 

ENQ 

0. 000 

47 

STI 

1. 375 

15 

INI 

0. 000 

50 

MUA 

6. 875 to 9. 875 

15 

INA 

0. 000 

51 

DVA 

10.250 

15 

INQ 

0. 000 

52 

CPR 

1. 375 to 2. 625 

16 

XOI 

0. 000 

53 

TIA 

0. 000 

16 

XOA 

0. 000 

53 

TAI 

0. 000 

16 

XOQ 

0. 000 

/53 

TMQ 

0. 625 
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TABLE 5-2 (Cont'd) 


Basic 

Octal 

Code 

Mnemonic 

Code 

Execution 

Time 

(usee) 


Mnemonic 

Code 

Execution 

Time 

(usee) 

53 

TQM 

0. 625 

66 

UPAK 

10. 7+0. 9S^ 

53 

TMA 

0. 625 

67 

ADM & SBM 

®9+3. 1W+ 0. 75 S2 

53 

TAM 

0. 625 



@13+3. lw+ 1. 65 S 2 

53 

TMI 

0, 625 

67 

ZADM 

10,7 + 0. 9 S 2 

53 

TIM 

0. 625 

67 

CMP 

10. 7 + 0. 9T 

53 

AQA 

0. 000 

67 

TST 

©9. 4 

53 

AIA 

0, 000 



® 8, 5 + 0. 9 S 1 

53 

lAI 

0. 000 

67 

TSTN 

® 8. 5 + 0. 9 Si 

54 

LDI 

1. 375 

70 

LBR 

4. 9 




70 

JMP 

1. 44 

55 

RIS 

0. 000 







70 

SBR 

4. 9 

56 

MUAQ 

16.0 to 19. 0 

71 

SRCE 


57 

DVAQ 

25. 5 

71 

SRCN 

>!< 

60 

FAD 

4. 850 to 6. 250 

72 

MOVE 


61 

FSB 

4. 850 to 6. 250 

73 

INPC 


62 

FMU 

16.0 

73 

INAC 

> 1 = 

63 

FDV 

19.0 

74 

INPW 

>N 

64 

MVE 

10. 7 + 0. 9 S 

74 

INAW 

>;< 

64 

MVBF 

10.7+0. 9%2 

75 

OUTC 


64 

MVZF 

12. 9+0, 9S2 

75 

OTAC 

+ 

64 

MVZS 

10.7+0. 9S2 

76 

OUTW 


64 

FRMT 

10.7+0. 9 S 2 

76 

OTAW 


64 

EDIT 

Q>9+3. ltt+ 0. 75S 2 

77 

CON 

>;< 



® 13+3. 1«+1. 65 S 2 

77 

SEL 


65 

SCAN 

8.5 + 0. 9 S 2 

77 

EXS 

0. 000 

66 

CVBD 

17. 9 + 0. 92 [<» (1+M) + 

77 

COPY 

0. 000 



/3M^+8Nj^+20N2+28N3] 

77 

INS 

0. 000 

66 

CVDB 

® 13. 7 + 0. 92 (3N, + 

77 

CINS 

0. 000 



6 N 2 + 8 N 3 ) 

77 

INTS 

0 . 000 



® 13, 7 + 0. 92 (4Ni + 

77 

INCL 

0 . 000 



ION 2 + 14 N 3 - 1 ) 

77 

lOCL 

0 . 000 




77 

CILO 

0 . 000 

66 

DTA 

10.7 + 1. 1 S 







77 

CLCA 

0 . 000 

66 

ATD 

10, 7 1. 1 S 







77 

SSIM 

0 . 000 

66 

PAK 

10. 7 -i- 0. 9 Si 






^1 

77 

SCIM 

0 . 000 
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TABLE 5-2 (Cont'd) 


Basic 

Octal 

Code 





Mnemonic 

Code 

Execution 

Time 

(usee) 

Basic 

Octal 

Code 

Mnemonic 

Code 

Execution 

Time 

(usee) 

ACI 

0. 000 

77 

AOS 

0. 000 

CIA 

0. 000 

77 

AIS 

0. 000 

JAA 

0. 000 

77 

OSA 

0. 000 

lAPR 

0. 000 


ISA 

0. 000 

PADS 

0. 0 to 40 ms 


SLS 

0. 000 

PRP 

0. 0 to 40 ms 


SFPF 

0. 000 

TMAV 

1.375 or 6.375 us 

77 

SBCD 

0. 000 

SBJP 

0. 000 

77 

DINT 

0. 000 

SDL 

0. 000 

77 

EINT 

0. 000 

CRA 

0. 000 

77 

CTI 


ACR 

0. 000 

77 

CTO 


APF 

PFA 

0. 000 

0. 000 

77 

UCS 

0. 000 


number of characters searched 
number of characters in source field (A) 
number of characters in result field (C) 

number of most significant 4r-bit binary groups (in the lower 24 bits to be 
converted) which have a zero value 

number of most significant 4-bit binary groups (in the upper 24 bits to be 
converted) which have a zero value (see example) 

number of characters up to and including three in number (For the CVBD 
instruction, the term character defines a binary group of 4 bits to the 
right of any consecutive lead groups which are all zero. See example.) 

number of characters from three, up to and including seven in number. 

(See example. ) 

number of characters greater than seven in number (For the CVBD 
instruction, the term character defines a binary group of 4 bits to the right 
of any consecutive lead groups which are all zero. See example. ) 

number of characters in the smaller of fields and 

If all upper 24 bits to be converted are zero, cs? = 1; if not a = 0. 

If one or more of the upper 24 bits to be converted is a "l", 13 = 1, if not 

jS = 0. 

number of characters in the longer of fields and § 2 - 

Dependent upon a variable signal response time from an external equipment 
or internal source; i. e. , Block Control, 

niomber of 4 character groups in field S 2 ■ 
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©@@ 0 @©© 


best case (no second pass) 
worst case (second pass required) 
best case (no carry propagation) 
worst case (maximum carry propagation) 

worst case (maximum carry propagation and second pass required) 
best case (field f zero) 
worst case (entire field = zero) 

SPECIAL PARAMETER EXAMPLES 


M-|^ = 2 in this case 

23 20 19 16 15 12 11 08 07 04 03 00 



N2 = 4 Ni = 3 


Data words are divided into six 4-bit groups internally by the CPU and are shown here 
only to illustrate the parameters necessary for determining the instruction execution 
time. 
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Halt and Stop Instructions 

Operation Field 


HLT 00 
SLS 77 

UCS 77 


Address Field 

Interpretation 

m 

Halt 

Selective stop 
Unconditional stop 


HLT 

Hall 


1 

23 


le 

17 15 

14 


00 

i 1 

00 

1 ° 1 

m 

ji 









Instruction Description: Unconditionally halt at this instruction. Upon restart¬ 
ing, RNI from address m. 

Comments: Indirect addressing and address modification may not be used. 


SLS 

Selective Stop 



Instruction Description: Program execution halts if the SELECT STOP switch 
on the console is set. RNI from address P + 1 upon restarting. 

Comments: Bits 00 through 11 should be loaded with zeros. 



Instruction Description: This instruction unconditionally stops the execution of 
the current program. RNI from address P + 1 upon restarting. 

Comments: Bits 00 through 11 should be loaded with zeros. 
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Enter Instructions 


Operation Field 

Address Field 

Interpretation 

ENI 

14 

y,b 

Enter index b with y 

ENA 

14 

y 

Enter A with y 

ENA, S 

14 

y 

Enter A with y and extend sign of y 

ENQ 

14 

y 

Enter Q with y 

ENQ, S 

14 

y 

Enter Q with y and extend sign of y 

ECHA 

11 

Z 

Enter A with z 

ECHA, S 

11 

Z 

Enter A with z and extend sign of z 


ENI 

Enter Index with y 


23 18 17 16 15 14 00 


HDB 

B 

D 



b = index register designator 

Instruction Description; Clear index register and enter y directly into it. 
Comments: If b = 0, this is a no-operation instruction. 


ENA 

Enter A w'th y 


23 18 17 15 14 


00 



Instruction Description: Clear the A register and enter y directly into A. 

ENA, S 

Enter A with y^ 

Sign Extendi 

Instruction Description: Same as ENA except the sign of y is extended. 


ENQ 

Enter Q with y 


1817 1514 


23 


18 17 


14 


00 


Instruction Description: Clear the Q register and enter y directly into Q. 


ENQ, S 
Enter Q with y. 
Sign Extended 


23 


18 17 15 14 


Instruction Description: Same as ENQ except the sign of y is extended. 
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ECHA 

£nfer Chcwacter 
Address inio A 


23 18 17 16 


00 



Instruction Description: Clear A; then enter a 17-bit operand z (usually a 
character address) into A. 


ECHA, $ -. ^ , 23 _ 18 1716 _ 00 

Enter Character 11 i z 

Address into A, Sign Extended 


Instruction Description: Clear A; then enter a 24-bit operand (17-bit z plus 
7 bits of sign extension) into A. 


NOTE 

If is often desirable to perform operations with the A or Q registers 
using a negative operand. By using the sign extension feature of cer¬ 
tain instructions, 14-bit negative operands become available. This 
feature eliminates the need, in many instances, to reference prestored 
operands. 

The following examples illustrate the use of sign extension in some instructions: 

EXAMPLE A: To enter negative zero into Q, execute a 14 5 77777. 

EXAMPLE B; To increase (A) by -17, execute a 15477760 instruction. 

(A) = 00066667 (arbitrary value) 

77777760 

00066647 

(end around carry) _1 

00066650 =(A) after instruction-execution 

In all cases of sign extension, bit 14 for 15-bit y operands and bit 16 for 17-bit 
z operands determines the sign of the quantity. 
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Skip Instructions 


Operation Field 

Address Field 

Interpretation 

ISE 

04 

y,b 

-g- 

Skip next instruction if (B ) = y 


ASE 

04 

y 

Skip next instruction if (A) = y 


ASE, S 

04 

y 

Skip next instruction if (A) = y. 
y is extended. 

Sign of 

QSE 

04 

y 

Skip next instruction if (Q) = y 


QSE, S 

04 

y 

Skip next instruction if (Q) = y. 
y is extended, ^ 

Skip next instruction if (B^) > y 

Sign of 

ISO 

05 

y.b 


ASG 

05 

y 

Skip next instruction if (A) > y 


ASG, S 

05 

y 

Skip next instruction if (A) > y. 

Sign of 




y is extended. 


QSG 

05 

y 

Skip next instruction if (Q) > y 


QSG, S 

05 

y 

Skip next instruction if (Q) > y. 
y is extended. 

Sign of 

ISI 

10 

y.b 

Index skip, incremental 


ISD 

10 

y,b 

Index skip, dec remental 



NOTE 

The SSH (10. 0) instruction, which also uses 
a Skip exit, is described in the Shift and Scale 
Instruction group. 




23 

18 17 16 15 14 


00 



04 

0 b 

y 



b = index register designator 

Instruction Description: If (B^) = y, skip to address P+2; if not, RNI from ad¬ 
dress P+1. 

Comments: If b = 0, y is compared to zero. 
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Instruction Description: If (A) = y, skip to address P+2; if not, RNI from ad- 
dress P+1. 

Comments: Only the lower 15 bits of A are used for this instruction. 


ASE, S 
Skip Next 

Instruction if (A)= y. Sign Extended 


23 18 yr 15 14 


00 



Instruction Description: Same as ASE except the sign of y is extended. All 
24 bits of A are recognized. 


QSE 

Skip Next 

Instruction if (O) = y 


23 18 17 15 14 


00 



Instruction Description: If (Q) = y, skip to address P+2; if not, RNI from ad¬ 
dress P+1. 

Comments: Only the lower 15 bits of Q are used for this instruction. 


QSE, S 23 18 17 15 14 00 

Skip Next 

Instruction if (Q) = y, Sign Extended 



Instruction Description: Same as QSE except the sign of y is extended. All 24 
bits of Q are recognized. 
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23 


18 17 16 15 14 


00 


b = index register designator 

Instruction Description; If (B°) are equal to or greater than y, skip to address 
P+2; if not, RNI from address P+1. {B°) and y are 15-bit positive numbers. 

Comments: If b = 0, y is compared to zero. 


ruction if 


Instruction Description: I f (A) are equal to or greater than y, skip to address 
P+2; if not, RNI from address P+1. Only the lower 15 bits of A are used. 

Comments: (A, . j.) and y are considered 15-bit positive numbers. 


Instruction if (A) ^ Si 


Instruction Description: Same as ASG except the sign of y is extended. All 24 
bits of A are recognized. Positive zero (00000000) is recognized as greater 
than negative zero (77777777). 


QSG 

Skip Next 

Instruction if (QJ ^ y 


Instruction Description: If (Q) are equal to or greater than y, skip to address 
P+2; if not, RNI from address P+1, Only the lower 15 bits of Q are used. 

Comments: (Q ) and y are considered 15-bit positive numbers. 



• Skip Next 

Instruction, if fOJ ^ y. 

Instruction Description: Same as QSG except the sign of y is extended. All 24 
bits of Q are recognized. Positive zero (00000000) is recognized as greater 
than negative zero (77777777). 


Rev. B 


5-30 









/s/ 

Index Skip, 
Incremental 


23 18 17 16 1514 


10 0 b 


y 


b = index register designator 

Instruction Description: If (B°) = y, clear and skip to address P+2; if not, 
add one to (B^) and RNI from address P+1. 

Comments: The 10,0 instruction is a SSH (storage--shift) instruction, described 
later in this section. 



ISD 

Index Skip, 
Decremenfal 


18 17 16 15 14 


I b 


b = index register designator 

Instruction Descripti on: If (B^) = y, clear B^ and skip to address P+2; if not, 
subtract one from (B^) and RNI from address P+1. 

Comments: When b = 0, RNI from P+1 if y / 0; RNI from P+2 if y = 0. 
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Inter-Register Transfer Instructions 


Operation Field 

Address Field 

Interpretation 

AQA 

53 


Transfer (A) + (Q) to A 

AIA 

53 

b 

Transfer (A) + (B^) to A 

lAI 

53 

b 

Transfer (B^) + (A) to B^* 

TIA 

53 

b 

Transfer (Bt>) to A 

TAI 

53 

b 

Transfer (A) to B^ 

TMQ 

53 

V 

Transfer (Register v) to Q 

TQM 

53 

V 

Transfer (Q) to Register v 

TMA 

53 

V 

Transfer (Register v) to A 

TAM 

53 

V 

Transfer (A) to Register v 

TMI 

53 

V, b 

Transfer (Register v) to B^ 

TIM 

53 

V, b 

Transfer (B^) to Register v 

ELQ 

55 


Transfer (Ej^) to Q 

EUA 

55 


Transfer (Ey) to A 

EAQ 

55 


Transfer (EuEp,) to AQ 

QEL 

55 


Transfer (Q) to El 

AEU 

55 


Transfer (A) to E-q 

AQE 

55 


Transfer (AQ) to EyE^, 

AIS 

77 


Transfer (A 00 - 02 ) 

ISA 

77 


Transfer ^SR) to Aoo-02 

AOS 

77 


Transfer (A 00 -O 2 ) '•^0 OSR 

OSA 

77 


Transfer (OSR) to Aoo-02 

ACI 

77 


Transfer (A 00 -O 2 ) CIR 

CIA 

77 


Transfer (CIR) to Aoo-02 

APF 

77 

w, b 

Transfer (Aqo-II) to PIF location 'w' 

PFA 

77 

w, b 

Transfer (PIF location 'w') to Aqo-H 

CRA 

77 


Transfer (CR) to Aoo-05 

ACR 

77 


Transfer (Aoo-05) to CR 

JAA 

77 


Transfer EJA to Aoo-14 



Instruction Description: Add the (A) to the (Q) and transfer the sum to A. 

Comments: (Q) remain unchanged. Bits 00 through 11 should be loaded with 
zeros. 
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AIA 

(A) i (B") ■ > A 


23 


18 17 16 15 14 


12 11 


00 



b = index register designator 

Instruction Description: Add the (A) to the (B^) and transfer the sum to A. 

Comments: Bits 00 through 11 should be loaded with zeros. The sign of (B^) is 
is extended prior to the addition. (B^) remain unchanged. 



b = index register designator 

Instruction Description: Add the (A) to the (b'^) and transfer the sum to B^. 

Comments: Bits 00 through 11 should be loaded with zeros. The sign of the 
original (Bt>) is extended prior to the addition. The upper 9 bits pf the sum are 
lost when the sum is transferred to the Index register. If b=0, this becomes a 
No-Op instruction. 



b = index register designator 
Instruction Description: Transfer the (B^) to A. 

Comments: Bits 00 through 11 should be loaded with zeros. No sign extension on 
BO. Prior to the transfer, (A) are cleared. If b = 0, zeros are transferred to A. 


I TAI 

{A)-^B'’ 


23 


18 17 16 15 14 


12 I I 


00 



b = index register designator 
Instruction Description: Transfer the (A) to B^. 

Comments: Bits 00 through 11 should be loaded with zeros. The (A) remain 
unchanged. If b = 0, this becomes a no-operation instruction. 
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TMQ 

(y)-^Q 


23 18 17 16 15 14 12 II 06 05 00 



V = register file number, 00-77g 
Instruction Description: Transfer the (v) to Q. 

Comments: Bits 06 through 11, 15 and 16 should be loaded with zeros. 

TQM 


23 18 17 16 15 14 12 I I 06 05 00 



V = register file number, 00-77g 
Instruction Description: Transfer the (Q) to v. 

Comments: Bits 06 through 11, 15 and 16 should be loaded with zeros. 


TMA 

(v)->A 


23 18 17 16 15 14 12 I I 06 05 00 



V = register file number, 00-77g 
Instruction Description: Transfer the (v) to A. 

Comments: Bits 06 through 11, 15 and 16 should be loaded with zeros. 


TAM 
(A) -v 


23_ 18 17 16 15 14 12 11 06 05_00 


53 

H 


1 ^ 1 

'/////yy/zy/j 

V 


■ 






V = register file number, 00-77g 
Instruction Description: Transfer the (A) to v. 

Comments: Bits 06 through 11, 15 and 16 should be loaded with zeros. 
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23_IB 17 16 15 14 12 11_06 05_00 



- 





53 

1 

b 

3 


V 


b = index register designator 
V = register file number, 00-77g 

Instruction Description: Transfer the lower 15 bits of (v) to Bt>. 

Comments : Bits 06 through 11 should be loaded with zeros. If 'b' = 0, this 
becomes a no-operation instruction. 



b = index register designator 
V = register file number, 00-77g 

Instruction Description: Transfer (B^) to v. The upper nine bits of 'v' are cleared. 

Comments : Bits 06 through 11 should be loaded with zeros. If 'b' = 0, all of 
(v) are cleared. 


5-35 


Rev. A 








23 


18 17 15 14 


00 


l"- t\i"i;'--.::V; '‘:Vi:'i'\'V;\>VV’".'^ ':■ ' " 

hir^:V:‘'V.:Uv-^' .^fV-.'.. ■ ■■'■ ■; 


Instruction Description: Transfer the (E^) to Q. Bits 00-14 should be loaded 
with zeros. 


55 2 


Instruction Description: Transfer the (E-y) to A. Bits 00-14 should be loaded 
with zeros. 




55 3 



Instruction Description; Transfer the (E^Ej^) to AQ. Bits 00 - 14 should be 
loaded with zeros. 






55 5 


Instruction Description : Transfer the (Q) to E^^. Bits 00-14 should be loaded 
with zeros. 



Instruction Description: Transfer the (A) to Ey Bits 00 - 14 should be loaded 
with zeros. 

AQE 

(AQ)^E 



Instruction Description: Transfer the (AQ) to E^E^^. Bits 00-14 should be 
loaded with zeros. 
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AIS 


Instruction Description ; 
State register. 


ISA 


Instruction Description: 


AOS 

osR 


Instruction Description: 
register. 


OSA 

rosR;^A„.« 


Instruction Description: 


23 18 17 12 11 0908 00 


77 

66 

4 

000 


Transfer (A , „n rvi j no) to the Instruction 

bits 00, 01, and 02 


23 18 17 12 M 09 08 00 


77 

67 

1 ^ 1 

0 0 0 


Transfer (ISR) to A 


(bits 00, 01, and 02)' 


23 1817 1211 


00 


77 


66 


0000 


Transfer ^ ^ to the Operand State 


23 18 17 12 II 


00 


77 67 


0 0 0 0 


Transfer (OSR) to A 


(bits 00, 01, and 02)* 
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Instruction Description: 
register. 


Transfer (A. j no) to the Channel Index 

bits 00, 01, and 02 


Comments : Bits 00 through 11 should be loaded with zeros. This instruction is 
used to set the CIR to a value from 0 to 7. When referenced, (CIR) are logically 
OR'ed with the channel designator, ch, in the following instructions; 


73 through 76 I/O instructions 

77. 2 

Copy External Status 

77. 0 

Connect 

77. 3 

Sense Internal Status 

77. 1 

Select Function 

77. 3 

Copy Internal Status 

77. 2 

Sense External Status 

77. 4 

Sense Interrupt 


CIA 

(CIR) ^ AoO-02 



Instruction Description; 


Transfer (CIR) to 


Comments: Bits 00 through 11 should be loaded with zeros. 
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2 

b = index designator, B only 

Instruction Description: Transfer (A, , ,, ) to the 12-bit index at 

PTge Index File address 'w'. through 11 

Comments : If bit 11 is a "l”, (B ) are used for address modification. Bits 07 
through 10 should be loaded with zeros. This instruction is a no-operation 
instruction if the 3311 Multiprogramming option is not present in the system. 


PFA 

(PtF)-^Aoo.u 


2 

b = index designator, B only 

Instruction Description: Transfer the 12-bit index at Page Index File address 
w to QQ through 11). 

2 

Comments: If bit 11 is a "l", (B ) are used for address modification. Bits 07 
through 10 should be loaded with zeros. This instruction is a no-operation 
instruction if the 3311 Multiprogramming option is not present in the system. 


23 IB 17 12 II 10 07 06 00 
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CRA 

(CR)- 


23 18 17 12 II 


00 


77 


63 


0000 


Instruction Description : Transfer the (CR) to the lower 6 bits of A. The 
Condition register is cleared upon completion of the transfer. 

Comments : This instruction should be used in interrupt routines during Exec¬ 
utive Mode operations. All interrupts are disabled between interrupt recognition 
and the execution of the instruction. Program conditions represented by the 
Condition register are listed below: 


Bit 00 
Bit 01 
Bit 02 
Bit 03 
Bit 04 
Bit 05 


Boundary Jump 
Destructive Load A 
Operand Relocation Using OSR 
Program State Jump 
Interrupt System Enabled 
Program State 



23 18 

17 12 

II 09 

08 00 


77 

63 


0 0 0 


Instruction Description: Transfer the Condition register. 

Comments: This instruction should be used at the end of interrupt routines 
during^jTecutive mode to restore the Condition register to its original state. 

All interrupts are disabled between the execution of the ACR instruction and the 
jump instruction used to exit from interrupt routines. Refer to the CRA 
instruction for the conditions represented in the Condition register. 


JAA 

Jump Address —^ A 


23 IB 17 12 II 


00 



Instruction Description: Transfer the address, P, of the last jump type of in- 
struction occurring in Program State, to 00 through 14). 

Comments : The LJA (Last Jump Address) can also be displayed on the console 
when the LJA switch is depressed and the computer is stopped (refer to Section 
7). Bits 00 through 11 should be loaded with zeros. 
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Jump Instructions 


Operation Field 

Address Field 

Interpretation 

SJl-6 

00 

m 

Jump if appropriate key (1-6) is set 

UJP, I 

01 

m, b 

Unconditional jump 

JMP, HI 

70 

m 

Jump on Positive result 

JMP, ZRO 

70 

m 

Jump on Zero result 

JMP, LOW 

70 

m 

Jump on Negative result 

IJI 

02 

m, b 

Index jump; Incremental index 

IJD 

02 

m, b 

Index jump; Decremental index 

AZJ 

03 

m 

Compare A with zero for Jump condition 

AQJ 

03 

m 

Compare A with Q for Jump condition 

RTJ 

00 

m 

Return jump 


SJl-6 

Selective Jump 


23 18 17 15 14 


00 


00 


m 


j = jump keys 1 to 6 
m = jump address 

Instruction Description : Jump to address m if Jump key j is set; otherwise, 
RNI from address P+1. 

Comments : Indirect addressing and address modification may not be used. 



UJP 

Unconditional Jump 


23 18 17 16 16 14 00 


01 

0 

E 

m 


a = addressing mode designator 
b = index register designator ^ 
m = storage address; M = m + (B°) 

Instruction Description : Unconditionally jump to address M. 

Comments : Indirect addressing and indexing may be used. 
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JMP, ZRO 
Jump if result 0 


23 18 17 IS 14 


00 


70 


m 


m = jump address 

Instruction Description : Sense the status of the BCR (BDP Condition Register). 
If the result from the preceding BDP operation was zero, jump to address m. 


Comments : If the console BDP switch is not active or if the BDP is not present 
in the system, this instruction is trapped. (Refer to Section 4.) 


JMP, HI 

Jump if result is + or high 


23 18 17 IS 14 


00 



m = jump address 

Instruction Description : Sense the status of the BCR (BDP Condition Register). 
If the result from the preceding BDP operation was positive or greater than 
zero, jump to address m. 

Comments : If the console BDP switch is not active or if the BDP is not present 
in the system, this instruction is trapped. (Refer to Section 4.) 


JMP, LOW 
Jump if result Is — 


low 


18 17 15 14 


00 


m = jump address 

Instruction Description : Sense the status of the BCR (BDP Condition Register), 
if the result from the preceding BDP operation was negative or less than zero, 
jump to address m. 

Comments : If the BDP is not in the system, or the console BDP switch is not 
active, this instruction is trapped. (Refer to Section 4.) 
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b = index register designator 
m = jump address 

Instruction Description : If b = 1, 2, or 3, the respective Index register is ex¬ 
amined: 

1. If (B°) = 00000, the jump test condition is not satisfied; RNI from address 
P+1. 

2. If (B^) ^ 00000, the jump test condition is satisfied. One is added to (B^); 
jump to address m and RNI. 

Comments : If b = 0, this is a No-Operation instruction; RNI from address 
P+1. Indirect addressing and jump address modification may not be used. The 
counting operation is done in a one's complement additive accumulator. Negative 
zero (77777) is not generated because the count progresses from: 77775, 77776, 
to 00000 (positive zero) and stops. If negative zero is initially loaded into B^, 
the count progresses: 77777, 00001, 00002, etc. In this case, the counter must 
increment through the entire range of numbers to each positive zero. 
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23 


18 17 16 15 14 


00 



b = index register designator 
m = jump address 

Instruction Description : If b = 1, 2,or 3, the respective Index register is ex¬ 
amined: 

1. If (B^) = 00000, the Jump Test condition is not satisfied; RNI from address 
P+1. 

2. If (B^) f 00000, the Jump Test condition is satisfied. One is subtracted 
from (B^*); jump to address m and RNI. 

Comments : If b = 0, this is a no-Operation instruction; RNI from address 
P+1. Indirect addressing and jump address modification may not be used. If 
negative zero (77777) is initially loaded into Bt>, the count decrements through 
the entire range of numbers to reach 00000 before the program will RNI from 
P+1. 
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23 


18 17 16 15 14 


00 


AZJ 

Condition Compare 
A with Zero, Jump 


03 0 j 


j = jump designator (0-3) 
m = jump address 

Instruction Description : The operand in A is algebraically compared with zero 
for an equality, inequality, greater-than or less-than condition (see table). 

If the test condition is satisfied, program execution jumps to address m. If the 
test condition is not satisfied, RNI from address P+1. 

Comments : Positive zero (00000000) and negative zero (77777777) give identi¬ 
cal results when j = 0 or 1. When j = 2 or 3, negative zero is recognized as 
less than positive zero. Indirect addressing and address modification may not 
be used. 
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23 


18 17 16 15 14 


00 


AQJ 

Condition Compare 
A with Q, Jump 


3 = 0-3 jump designator (0-3) 
m = jump address 

Instruction Description : The quantity in A is algebraically compared with the 
quantity in Q for equality, inequality, greater-than or less-than condition (see 
table). If the test condition is satisfied, program execution jumps to address 
m. If the test condition is not satisfied, RNI from address P+1. 

Comments : This instruction may be used to test (Q) by placing an arbitrary 
value in A for the comparison. Positive and negative zero give identical results 
in this test when j = 0 or 1, When j = 2 or 3, negative zero is recognized as 
less than positive zero. Indirect addressing and address modification may not 
be used. 
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RTJ 

Return Jump 


23 


18 17 IS 14 


00 



m = jump address 

Instruction Description : The address portion of m is replaced with the return 
address, P+1. Jump to location m+1 and begin executing instructions at that 
location. 

Comments : This instruction should not be used to transfer control from Monitor 
State to Program State. If an RTJ instruction is executed and the Boundary Jump 
flag is set (refer to SBJP instruction), the STO cycle is executed in Monitor State, 
i. e. , address 'P' is stored at address 'm' of the monitor program. Indirect 
addressing and address modification may not be used. An example of an executed 
RTJ instruction is illustrated on the following page. 
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CURRENT 

EXECUTION 

ADDRESSED 


EXECUTE THIS INSTRUCTION 

00500 00 7 33444 
( ^05oT 
00502 — - 


INSTRUCTION AT M 
IS USUALLY A JUMP 
BACK TO MAIN PROGRAM 
WITH PROGRAM EXECUTION 
COMMENCING AT P+1,00501 


RTJ INSTRUCTION AUTOMATICALLY 
CAUSES ADDRESS OP P+1,00501, 
TO BE PLACED IN LOWER 15 BITS 
OF M,33444,AND EXECUTES THE 
ADDRESS AT M+I,33445 


MEMORY 

ADDRESSES 




M 

M+l 
M + 2 


33444 

33445 — 

33446 ^ 





M+3 33447(01 0 33444 


LAST INSTRUCTION OF 
SUBROUTINE USUALLY 
CAUSES JUMP BACK TO 
M AND INSTRUCTION 
AT M IS EXECUTED 


RTJ EXECUTION EXAMPLE 




Load Instructions 


Operation Field 

Address Field 

Interpretation 

LDA, I 

20 

m, b 

Load A 

LACH 

22 

r, B^ 

Load A, Character 

LCA, I 

24 

m, b 

Load A, Complement 

LDL, I 

27 

m, b 

Load A, Logical 

LDAQ, I 

25 

m, b 

Load AQ 

LCAQ, I 

26 

m, b 

Load AQ, Complement 

LDQ, I 

21 

m, b 

Load Q 

LQCH 

23 

r, b2 

Load Q, Character 

LDI, I 

54 

m, b 

Load Index 


LDA 
Load A 


23 18 17 16 15 14 


00 


20 0 b 


m 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B ) 


Instruction Description : Load A with a 24-bit quantity from the storage address 
specified by M. 


Comments: Indirect addressing and address modification may be used. 


LACH 

Load A, Character 


23 18 17 16 _00 


22 


r 


16 02 0I00| 

00000-77777 

0-3 


word address 


character 

designator 


If b = 1, r is modified by index 
register R = r + (b1). 

If b = 0, r is not modified (r = R), 

Instruction Description : Load bits 00 through 05 of A with the character from 
storage specified by character address R. The A register is cleared prior to 
the Load operation. 

Comments : Indirect addressing may not be used. Characters are specified in 
storage as follows: 23_isit _izn_ pops _00 

0 12 3 

character designators 
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NOTE 


1 ^ 

Since the sign of B° is extended during character address modification, 
it is possible to only reference within ± 16, 383^^ characters. 


LCA 

Load A, Complemenf 


23 18 17 16 1514 _00 


24 

D 

D 

m 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (b“) 

Instruction Description : Load A with the ones complement of a 24-bit quantity 
from storage address M, 

Comments : Indirect addressing and address modification may be used. 



23_18 17 16 15 14_00 


27 

a 

0 

m 


a = addressing mode designator 
b = index register designator 
m = storage address; m=m+(Bt>) 

Instruction Description : Load A with the logical product (the AND function) of 
(Q) and the 24-bit quantity from storage address M. 


LDAQ 
Load AQ 


23_18 17 16 15 14_00 


25 

a 


m 


a = addressing mode designator 
b = index register designator ^ 
m = storage address; M = m + (B^) 

Instruction Description : Load the A and Q registers with the 24-bit quantities 
from addresses M and M+1, respectively. 

Comments : Addresses 77776 and 77777 should be used only if it is desirable to 
have M and M+1 as non-consecutive addresses, since one's complement arith¬ 
metic is used to form M+1. 
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23 


18 17 16 15 14 


00 


LCAQ 

Load AQ, Complement 


26 

B 

D 

m 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B*^) 

Instruction Description : Load registers A and Q with the complement of the 
24-bit quantities from addresses M and M+1, respectively. 

Comments : Addresses 77776 and 77777 should be used only if it is desirable to 
have M and M+1 as non-consecutive addresses, since one's complement arith¬ 
metic is used to form M+1. 



23_ 18 17 16 15 14_00 


> 21 

B 

D 

m 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (b“) 

Instruction Description : Load Q with a 24-bit quantity from storage address M. 
Comments: Indirect addressing and address modification may be used. 
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23 


18 17 16 


00 


LOCH 

Load Q, Character 


23 

b 

r 


16 02 01 OOl 

00000-77777 

0-3 


word address | 

character 

designator 


If b = 1, r is modified by 
index register R = r + (B^), 

If b = 0, r is not modified (r = R), 


NOTE 

Since the sign of B^ is extended during character address modification, 
it is possible to only reference within + 16, 383^^ characters. 

Instruction Description : Load bits 00 through 05 of Q with the character from 
storage specified by character address R. The Q register is cleared prior to 
the load operation. 

Comments : Indirect addressing may not be used. Characters are specified in 
storage as follows; 23 is 17 12 n oe 05 00 

0 12 3 

character designators 


LDI 

Load Index 


23 18 1716 1514 


00 


54 a b 


m 


a = addressing mode designator 
b = index register designator 
m = storage address (indexing not permit¬ 
ted) 

■L 

Instruction Description : Load the specified index register, B°, with the lower 
15 bits of the operand stored at address m. 

Comments : Indirect addressing may be used but address modification is not 
possible. During indirect addressing only a and m are inspected. Symbol b 
from the initial instruction specifies which index register is to be loaded with 
the lower 15-bits from the storage address. 
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Store Instructions 


Operation Field 

Address Field 

Interpretation 

STA, I 

40 

m, b 

Store A 

SACK 

42 

r, b2 

Store A, character 

STAQ, I 

45 

m, b 

Store AQ 

STQ, I 

41 

m, b 

Store Q 

SQCH 

43 

r, B^ 

Store Q, character 

STI, I 

47 

m, b 

Store index 

SWA, I 

44 

m, b 

Store 15-bit word address 

SC HA 

46 

m, b 

Store 17-bit character address 


. V" ' • 



23 


18 17 16 15 14 


00 




□ 

40 

a b 

m 







a = addressing mode designator 
b = index register designator ^ 
m = storage address; M = m + (B*^) 

Instruction Description : Store (A) at the storage address specified by M. The 
(A) remain unchanged. 
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23 


18 17 16 


00 


SACH 

Store A, Character 


42 


02 oloo; 


00000-77777 


0-3 


word address 


character 

designator 

If b = 1, r is modified by 
index register R = r -t- (B^), 

If b = 0, r is not modified (r = R). 


Instruction Description : Store the contents of bits 00 through 05 of the A reg¬ 
ister in the specified character address. All of (A) and the remaining three 
characters in storage remain unchanged. 

Comments : Indirect addressing may not be used. Characters are specified in 
storage as follows: 

23 _ 18 17 _1211_ 06 05 _00 

I 0 i I 2 3 I 


character designators 


NOTE 

Since the sign of B^ is extended during character address modification, 
it is possible to only reference within ± 16, 383 ^q characters. 


STAQ 
Store AQ 


23 18 17 16 15 14 


00 


45 a b 


m 


a = addressing mode designator 
b = index register designator ^ 
m = storage address; M = m -l- (B^) 

Instruction Description : Store (A) and (Q) in the storage locations specified by 
address M and M+1, respectively. The (A) and (Q) remain unchanged. 

Comments : Address 77776 and 77777 should be used only if it is desirable to 
have M and M-i-1 as non-consecutive addresses, since one's complement arith¬ 
metic is used to form M+1. 
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STQ 
Store O 


23 18 17 16 15 14 00 

41 

0 

E 

m 


a = addressing mode designator 
b = index register designator ^ 
m = storage address; M = m + (B°) 


fostruction Description : Store (Q) at the storage address specified by M. The 
(Q) remain unchanged. 


SQCH 

Store Q Choiacter 


23_[817 16_W 


43 


r 


16 OZOlOol 

00000-77777 

0-3 


\ _ / 


word address 


character 

designator 


If b = 1, r is modified by 
index register B^; R = r + (B^). 

If b = 0, r is not modified, (r = R). 


Instruction Description : Store the contents of bits 0 through 5 of the Q register 
in the specified character address. All of (Q) and the remaining three charac¬ 
ters in storage remain unchanged. 

Comments : Indirect addressing may not be used. Characters are specified in 
storage as follows: 

23_1817_I2ij_ 06 OS _00 

0 12 3 

character designators 

NOTE 

Since the sign of B^ is extended during character address modification, 
it is possible to reference only within ± 16, 383 j^q characters. 
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18 17 16 15 14 


00 


a b 


a = addressing mode designator 
b = index register designator 
m = storage address (indexing not permit¬ 
ted) 

Instruction Description : Store the contents of the specified index register, 
in the lower 15 bits of storage address m. The upper 9 bits of m and all of 
(B^) remain unchanged. 

Comments : Indirect addressing may be used, but address modification is not 
possible. During indirect addressing only a and m are inspected. The b desig¬ 
nator from the initial instruction specifies the Index register that will have its 
contents stored. If b = 0, zeros are stored in the lower 15 bits of m. 


SWA 

Store Word Address 


23 18 17 16 15 14 


00 


44 


m 


a = addressing mode designator 
b = index register designator 
m = storage address; (M = m + (B°) 

Instruction Description : Store the lower 15 bits of (A) in the designated ad¬ 
dress M. The upper 9 bits of M and all of (A) remain unchanged. 


SCHA 

Store 

Character Address 


23 18 17 16 15 14 00 

46 

0 


m 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B°) 

Instruction Description : Store the lower 17 bits of (A) in the address designated 
by M. The upper 7 bits of M and all of (A) remain unchanged. 
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Shift and Scale Instructions 


Operation Field 

Address Field 

Interpretation 

SSH 

10 

m 

Storage shift 

SHA 

12 

k, b 

Shift A 

SHQ 

12 

k, b 

Shift Q 

SHAQ 

13 

k, b 

Shift AQ 

SCAQ 

13 

k. b 

Scale AQ 


55^ 2S_ 18 17 15 14 _00 

Storage Shift | i° | o | ^ 


m = storage address 

Instruction Description: Sense bit 23 of the quantity stored at address m. If bit 
23 = ”0" (positive), RNI from P + 1; if negative RNI from P + 2. Shift (m) 

one place left, end around, and replace it in this same storage location. 

Comments : Address modification may not be used. 


SHA 
Shift A 


23 18 17 16 15 14 


00 


12 0 b 


k 


b = index register designator 
k = unmodified shift count; K = k + (B^) 

Instruction Description : (B^) and k, with their signs extended, are added. If 
b = 0, the sign of k is still extended. The sign and magnitude of the 24-bit sum 
determine the direction and magnitude of the shift. The computer senses only 
bits 00-05 and 23 of the sum for this information. For left shifts, the shift 
magnitude is the lower 6 bits of K ; for right shifts, the complement of the lower 
6 bits of K equals the shift magnitude. 

Examples: 

Shift left six positions: K = 00000006 

Shift right six positions: K = 77777771 

Comments : During left shifts, bits reaching the upper bit position of the A 
(during SHA) or Q (during SHQ) registers are carried end-around. Therefore, 
a left shift of 24 places results in no change in (A) or (Q), A left shift that ex¬ 
ceeds 24 places results in an effective shift of K-24 (or K-48) places. 

During right shifts, the sign bit is extended and the bits are shifted end-off, A 
right shift of 23 or more places results in (A) or (Q) becoming all "O's" or all 
"I's", depending upon the original sign. 
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SHA/SHQ FLOW CHART 
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23 


18 17 16 15 14 


00 


SHQ 
Shift Q 


12 

0 

□ 

k 


b = index register designator 
k = shift count: K = k + (Bt>) 

Instruction Description: Shift (Q). Refer to SHA description. 


SHAQ 
Shift AQ 


23 18 17 16 15 14 00 


13 

a 

0 

k 


b = index register designator 
k = unmodified shift count; K = k+(Bb) 

Instruction Description : Shift (AQ). (B^) and k, with their signs extended, are 

added. If b = 0, the sign of k is still extended. The sign and magnitude of the 24- 
bit sum determine the direction and magnitude of the shift. The computer senses 
only bits 00-05 and 23 of the sum for this information. For left shifts, the shift 
magnitude is the lower 6 bits of K; for right shifts, the complement of the lower 
6 bits of K equals the shift magnitude. 

Examples: 

Shift left three places: K = 00000003 

Shift right three places: K = 77777774 


Comments : During left shifts, bits reaching the upper bit position of the A regis¬ 
ter are carried end-around to the lowest bit position of Q. Therefore, a left 
shift of 48 places results in no change in (AQ). A left shift exceeding 48 places 
results in an effective shift of K-48 places. During right shifts, the sign bit is 
extended and the bits are shifted end-off. A right shift of 47 or more places 
results in (AQ) becoming all "O's" or all "I's", depending upon the original sign. 



23 18 17 16 15 14 00 


t3 

0 

0 

k 


b = index register designator 
k = scale factor 

K = residue = k minus the munber of shifts. 
If b = 1,2, or 3, then K —B^ 

Instruction Description: (AQ) are shifted left, end-around, until the 2 highest 
order bits (46 and 47) are unequal. If (AQ) should initially equal positive or 
negative zero, 48^0 shifts are executed before the instruction terminates. During 
scaling, the computer counts the number of shifts. A quantity K, called the re¬ 
sidue, is equal to the scale factor 'k' minus the number of shifts made. If b = 0, 
this quantity is discarded; if b = 1,2, or 3, the residue is transferred to the 
designated index register. 
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Arithmetic Instructions 


Operation Field 

Address Field 

Interpretation 

ADA, I 

30 

m, b 

Add to A 

RAD, I 

34 

m, b 

Replace add 

SBA, I 

31 

m, b 

Subtract from A 

ADAQ, I 

32 

m, b 

Add to AQ 

SBAQ, I 

33 

m, b 

Subtract from AQ 

MUA, I 

50 

m, b 

Multiply A 

DVA, I 

51 

m, b 

Divide A 

MUAQ, I 

56 

m, b 

Multiply AQ 

DVAQ, I 

57 

m, b 

Divide AQ 

FAD, I 

60 

m, b 

FP addition to AQ 

FSB, I 

61 

m, b 

FP subtraction from AQ 

FMU, I 

62 

m, b 

FP multiplication of AQ 

FDV, I 

63 

m, b 

FP division of AQ 

ADM 

67 

r, Br, Si,s, Bs, S 2 

Add fields 

SBM 

67 

r, Br, Si ,s, Bs, S 2 

Subtract fields 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B^) 

Instruction Description : Add the 24-bit operand located at address M to (A) 
The sum replaces the original (A). 



18 17 1615 14 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B°) 


Instruction Description : Replace the 24-bit operand at address M with the sum 
of (M) and (A), The original (A) remain unchanged. 
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a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B^) 

Instruction Description: Subtract the 24-bit operand located at address M from 
(A). The difference replaces the original (A), 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B^) 

Instruction Description: Add the 48-bit operand located in addresses M and 
M+1 to (AQ). The sum is displayed in AQ. 

Comments: The upper 24 bits of the 48-bit operand in memory are contained 
at address M. 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B^) 

Instruction Description: Subtract the 48-bit operand located in addresses M 
and M+1 from (AQ). The difference is displayed in AQ. 
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23 


16 17 16 15 14 


00 


MUA 

Multiply A 


so a b 


m 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B°) 

Instruction Description: Multiply (A) by the operand located at address M, 

NOTE 

The 48-bit product is displayed in QA. The higher order bits are in Q and 
the lower order bits are in A. 


OVA 
Divide A 


23 18 17 16 IS 14 


00 


51 0 b 


m 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B“) 

Instruction Description: Divide the 48-bit operand in AQ by the operand at 
storage address M. The quotient is displayed in A and the remainder with sign 
extended is displayed in Q. If a divide fault occurs, the operation halts and 
program execution advances to the next address. The final (A) and (Q) are 
meaningless if a divide fault occurs. 
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MUAQ 
Multiply AQ 


23 IB 17 16 15 14 


00 


56 


0 b 


m 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B“) 

Instruction Description : Multiply (AQ) by the 48-bit operand in addresses M 
and M+1. The 96-bit product is displayed in AQE, 

Comments: Refer to Figure 5-5 for operand formats. 


23 


18 17 16 15 14 


00 


57 

1 


m 










a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B^*) 

Instruction Description: Divide (AQE) by the 48-bit operand in addresses M 
and M+1, The quotient is displayed in AQ, and the remainder with its sign ex¬ 
tended is displayed in E. 

Comments : If a divide fault occurs, program execution advances to the next 
address. The final contents of AQ and E are meaningless if a divide fault 
occurs. Refer to Figure 5-5 for operand formats. 

NOTE 

Figure 5-5 illustrates operand format and bit allocations for all floating 
point instructions. Refer to the Floating Point section of Appendix B 
for additional floating point considerations and examples. 
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Figure 5-5. Operand Formats and Bit Allocations 
for MUAQ and DVAQ Instructions 


(D 

< 

> 


divide; 


HOLDS THE LOWER 48 BITS OF A 
96-BlT DIVIDEND PRIOR TO 
EXECUTING A OVAO INSTRUCTION 


HOLDS A 48-BIT REMAINDER 
AFTER EXECUTING A OVAQ 
INSTRUCTION. 


multiply: 


HOLDS THE LOWER 48 BITS OF 
A PRODUCT AFTER EXECUTING 
A MUAQ INSTRUCTION 


47 

I _ _ CEl REGISTER 


UPPER 48 BITS 

OF A 96-BIT - DIVIDE -48-BIT DIVISOR 

DIVIDEND 


95 




48 

23 


00 23 


oo' 

,_ 

'• * {AJSeOISTER 

_ 

(0}RE6>5'rrR 

...-WSl 

1 1 
1 1 


47 




00 

i 

1 

23 


00 23 


oo' 

1_ 



(M + l) 

_J 

1 1 

1 1 


4S- BIT MULTIPLICAND. 

AFTER EXECUTING AN MUAQ INSTRUCTION - MULTIPLY - AS-BIT MULTIPLIER 

AO HOLDS THE UPPER 48 BITS OF THE 
96- BIT PRODUCT 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B°) 

Instruction Description: Add the 48-bit operand located in addresses M and 
M+1 to (AQ). The rounded and normalized sum is displayed in AQ. 

Comments : The higher order bits of E hold the portion of the operand that was 
shifted out of AQ during exponent equalization. 

Refer to Figure 5-6 for operand formats. 




a = addressing mode designator 
b = index register designator 
m^ = storage address; M = m + (B^) 

Instruction Description: Subtract the 48-bit floating point operand located at 
storage addresses M and M+1 from the floating point operand in AQ. The 
rounded and normalized difference is displayed in AQ. 

Comments : The upper order bits of E hold the portion of the operand that was 
shifted out of AQ during the equalization of exponents. Refer to Figure 5-6 for 
operand formats. 
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23 


18 17 16 15 14 


00 


mu 

FP Multiplication of AQ 


62 a b 


m 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B^) 

Instruction Description : Multiply the 48-bit floating point operand in AQ by the 
floating point operand located at storage addresses M and M+1. The rounded 
and normalized product is displayed in AQ. 

Comments : Bits 12-47 of E hold the lower 36 bits of the 72-bit unnormalized 

product. Refer to Figure 5-6 for operand formats. 


FDV 

FP Division of AO 


23 18 17 16 15 14 


00 


63 


0 b 


m 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B^) 

Instruction Description: Divide the floating point operand in AQ by the 48-bit 
floating point operand located at storage addresses M and M+1. The rounded 
and normalized quotient is displayed in AQ. The remainder with sign extended 
appears in the E register. 

Comments: The sign of the remainder is the same as that of the dividend. 
Refer to Figure 5-6 for operand formats. 

NOTE 

The divisor must be properly normalized or a divide fault will result. 
Refer to Interrupt conditions. Section 4. 
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Figure 5-6. Operand Formats and Bit Allocations 
for Floating Point Arithmetic Instructions 



(EXPONENT AND FIRST 36 COEFFICIENT 
BIT RESULTS OF ALL FLOATING 
POINT OPERATIONS ) 



FSB EXPONENT EOUALIZATION 


SO 

o 

<! 

> 












ADM 

Add Field A to Field C 


23 


P + 1 

P + 2 


67 

0 

r 

23 21 20 19 18 

17 16 

00 

1 ° 

Br 


3 

s 

23 




12 

11 00 

Si 

S 2 


r = unmodified address of lowest order 
character in field A. R = r + [ Bj.] 

Br = index register flag for field A 

If Br = 1 or 3, use index register B^ 

If Br = 2, use index register B^ 

If Br = 0, no indexing 
s = unmodified address of lowest order 
character in field C. S = s + [Bs] 

Bs = index register flag for field C (same 
bit functions as Bj-) 

= 12-bit character count specifying the 
length of the A field 

S 2 = 12-bit character count specifying the 
length of the C field 

Instruction Description: Add the BCD contents of field A (addend) to field C 
(augend) proceeding from right to left. The upper 2 bits of the lowest order 
character in fields A and C contain the algebraic sign of their respective fields. 
The sign of the sum is in the upper 2 bits of the lowest order character of 
field C. This character is in the original address specified by S. 

Comments: Field A may be shorter than field C as carries can be set into pro¬ 
gressively higher order positions of field C. 

The BDP Condition register indicates a positive sign (00) or negative sign (10) 
according to the result in field C. A zero result may have either a positive or 
negative sign. If any character position of either field contains a lls “ code 
(or the sign character contains a 123 - 178 code), it is converted to zero before 
the add operation. 

A BCD fault is generated if one of the following conditions occur: 

1. An arithmetic carry is attempted out of the upper limit of field C. 

2. > S 2 

3. Zone portion (upper 2 bits) of characters in either field (except sign 
character) does not equal zero. 

4. Numeric portion (lower 4 bits) of characters in either field contains a 

BCD code greater than lip, except the sign character where a 12p code 
is legal. “ “ 

5. The lowest order character (sign character) in either field contains a 
72g code. 

Operation continues despite any BCD fault. 
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SBM 

Subtract Field p 

A from Field C 


P + 1 

P + 2 


23 


18 17 

16 

00 

67 

0 

r 

23 21 20 19 18 17 16 

00 

rn 

[sr 

Ss j 

s 

23 




12 

II 00 

Si 

S2 


r = unmodified address of the lowest 
order character in field A. 

R = r + [ Br] 

Bp = index register flag for field A 

If Br = 1 or 3, use index register B^ 
If Br = 2, use index register B^ 

If Br = 0, no indexing 
s = unmodified address of the lowest 
order character in field C, 

S = s + [Bs] 

Bg = index register flag for field C (same 
bit functions as Bp) 

S 2 ^ = 12-bit character count specifying the 
length of the A field 

$2 - 12-bit character count specifying the 
length of the C field 


Instruction Description: Subtract the BCD contents of field A (subtrahend) from 
field C (minuend) proceeding from right to left. The upper two bits of the lowest 
order character in fields A and C contain the algebraic sign of their respective 
fields. The sign of the difference is in the upper two bits of the lowest order 
character of field C. This character is in the original address specified by S. 

Comments: must be < S 2 since field C must accommodate the result of the 

subtraction. 

The BDP Condition register indicates a positive sign (00) or a negative sign (10) 
according to the result in field C. A zero result may have either a positive or 
negative sign. K any character position of either field contains a llg - 17g code 
(or the sign character contains a 12g " 17g code), it is converted to zero before 
the subtract operation. 

The conditions for generating a BCD fatilt are identical to those for the ADM 
instruction (see page 5-68). 
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Logical Instructions 


Operation Field 

Address Field 

Interpretation 

XOI 

16 

y.b 

Exclusive OR of index and y 

XOA 

16 

y 

Exclusive OR of A and y 

XOA, S 

16 

y 

Exclusive OR of A and y, sign of y ex¬ 
tended 

XOQ 

16 

y 

Exclusive OR of Q and y 

XOQ, S 

16 

y 

Exclusive OR of Q and y, sign of y ex¬ 
tended 

ANI 

17 

y. b 

AND of index and y 

ANA 

17 

y 

AND of A and y 

ANA, S 

17 

y 

AND of A and y, sign of y extended 

ANQ 

17 

y 

AND of Q and y 

ANQ, S 

17 

y 

AND of Q and y, sign of y extended 

SSA, I 

35 

m, b 

Selectively set A 

SCA, I 

36 

m, b 

Selectively complement A 

LPA, I 

37 

m, b 

Logical product A 


NOTE 

The LDL(Load A, Logical) instruction may be found in the LOAD IN¬ 
STRUCTIONS subsection. 


The following two examples use logical instructions and illustrate the Exclusive 
OR and AND functions: 


EXAMPLE A: 

(A) = 23456701 
Execute: 16 4 50321 = 

(XOA, S) 

Final (A) 


(Binary Equivalents) 

010 011 100 101 110 111 000 001 
111 111 111 101 000 oil 010 001 

101 100 011 000 110 100 010 000 

5 430 6420 


EXAMPLE B: 

(Q) = 23456701 
Execute: 17 7 77170 

(ANQ) 

Final (A) 


010 011 100 101 110 111 000 001 
000 000 000 111 111 001 111 000 

000 000 000 101 no ooi ooo ooo 

0005 6100 


Rev. A 


5-70 












23 


18 1716 1514 


00 



XOQ, S ' 
ive OR of Q and y 
gn Extended 


Instruction Description; Same as XOA except the sign of y is extended 


1817 15 14 


Instruction Description: Enter the selective complement (the Exclusive OR 
function) of y and (Q) back into the Q register. 


b = index register designator 


Instruction Description ; Enter the selective complement (the Exclusive OR 
function) of y and (Bb) back into the same index register. 


Comments: If b = 0, this is a no-operation instruction. 


1817 15 14 


Instruction Description: Enter the selective complement (the Exclusive OR 
function) of y and (A) back into the A register. 


1817 15 14 


23 18 17 15 14 


Instruction Description: Same as XOQ except the sign of y is extended. 
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23 


18 17 16 15 14 


00 


SSA 

Selectively Set A 


35 


0 b 


m 


p a = addressing mode designator 

'y' / ■ b = index register designator 

m = storage address; M = m + (B°) 

Instruction Description: Selectively set the bits in the A register to "I's" for 
all corresponding ^'I's'' in the quantity at address M. Initial "I's” in A remain 
unchanged, 

EXAMPLE: (A) = 23456710 = 010 011 100 101 110 111 001 000 

(M) = 76345242 = 111 110 011 100 101 010 100 010 

Final (A) = 111 111 111 101 111 111 101 010 

77757752 


SCA 

Selectively 
Complement A 


V» < < 


23 18 17 16 IS 14 


00 


36 


0 b 


m 


a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B°) 

Instruction Description: Selectively complement the bits in the A register that 
correspond to the "1" bits in the quantity at address M. 

EXAMPLE: (A) = 23456710 = 010 011 100 101 110 111 001 000 

(M) = 20341573 = 010 000 011 100 001 101 111 011 

Final (A) = 000 011 111 001 111 010 110 011 

03717263 



Rev. A 


5-72 
















■/-] i " a = addressing mode designator 

b = index register designator 
m = storage address; M = m + (B^) 

Instruction Description: Replace (A) with the logical product of (A) and (M). 


EXAMPLE; (A) = 23456710 = 010 011 100 101 110 111 001 000 

(M) = 45210376 = 100 101 010 001 000 011 111 110 

Final (A) = 000 001 000 001 000 011 001 000 

01010310 




of B' and 


18 1716 15 14 


b = index register designator 

Instruction Description: Enter the logical product (the AND function) of y and 
(B^) back into the same index register. 

Comments: If b = 0, this is a no-operation instruction. 
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Instruction Description : Enter the logical product (the AND function) of y and 
(Q) back into the Q register. 



Instruction Description: Same as ANQ except the sign of y is extended. 
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Masked Searches and Compare Instructions 


Operation Field 

Address Field 

Interpretation 

MEQ 06 

MTH 07 

CPR, I 52 

CMP 67 

CMP, DC 67 

m, i 
m, i 
m, b 

I", B]^, St, s, Bg ,§2 
r, Br, s,Bs, §2 

Masked equality search 

Masked threshold search 

Compare (within limits test) 

Compare fields 

Compare fields, with delimiting 


MEQ 
Masked 
Equality Search 


23 IB 17 15 14 


00 


06 


m 


i = interval designator, 0 to 7 
m = storage address 

Instruction Description : (A) is compared with the logical product of (Q) and (M). 
This instruction uses index register exclusively, m is modified just prior 
to step 3 in the test below. Instruction sequence follows; 

1. Decrement (B^) by i. (Refer to table below.) 

2. If (b 1) changed sign from positive to negative, RNI from P + 1; if not, 

3. Test to see if (A) = (Q) • (M). M = m + (b1). 

If (A) = (Q) • (M), RNI from P+2; if not, 

4. Repeat the sequence. 

Comments: i is represented by 3 bits, permitting a decrement interval selec¬ 
tion from 1 to 8. Address modification always utilizes (B^). Positive zero and 
negative zero are recognized as equal quantities. 
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23 


18 17 15 14 


00 


MTH 

Masked 

Threshold Search 


07 i 


m 


i = interval designator, 0 to 7 
m = storage address 

Instruction Description; (A) is compared with the logical product of (Q) and 
(M). This instruction uses index register exclusively, m is modified just 
prior to step 3 in the test below. 

Instruction Sequence; 

1. Decrement (B^) by "i". (Refer to table below.) 

2. If (B^) changed sign from positive to negative, RNI from P + 1; if not, 

3. Test to see if (A)> (Q) • (M). M = m + (B^), 

If (A)> (Q) • (M), RNI from P + 2; if not, 

4. Repeat the sequence. 

Comments: i is represented by 3 bits, permitting a decrement interval selection 
from 1 to 8, Address modification always utilizes (B^). Positive zero and negative 
zero are recognized as equal quantities. 
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CPR 

Compare 

(Wifbin Limits Test) 


23 18 17 16 15 14 _M 


52 

0 

H 

m 


a = addressing mode designator 
b = index register designator 
m = storage address; M=m+(Bt>) 

Instruction Description: The quantity stored at address M is tested to see if it 
is within the upper limits specified by A and the lower limits specified by Q, 

The testing proceeds as follows: 

1. Subtract (M) from (A). If (M) > (A), RNI from address P + 1; if not, 

2. Subtract (Q) from (M). If (Q) > (M), RNI from P + 2; if not, 

3. RNI from address P + 3. 

Comments: The final state of the A and Q registers remains unchanged. 

(A) must be ^ (Q) initially or the test cannot be satisfied. 77777777 is not sensed 
as negative zero. The following table is a synopsis of the CPR test: 


Test 

Jump Address 

Sequence 

if Test is Satisfied 

(M) > (A) 

P + 1 

(Q) > (M) 

P + 2 

(A) > (M) ^ (Q) 

P + 3 
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CPR FLOW CHART 









r = unmodified address of the highest 
order character in field A 
R = r + (Bj,) 

Bj- = index register flag for field A 

If Br = 1 or 3, use index register B^ 

If Br = 2, use index register b 2 
If Br = 0, no indexing 
s = unmodified address of the highest 
order character in field C. 

S = s + (Bs) 

Bg = index register flag for field C (same 
bit function as Bp) 

S. =12 bit character count specifying the 
length of the A field 
= 12 bit character count specifying the 
length of the C field 

Instruction Description : Compare characters in field A with field C proceeding 
from left to right. Terminate the operation when an unequal character compari¬ 
son occurs and RNI at P + 3. If the comparison condition is not satisfied when 
one of the fields has been completely examined, the remainder of the other field 
is examined for blanks (60 codes). If the remaining characters are all blanks, 
the compare operation is terminated as an equal comparison and the next instruc¬ 
tion is read from P + 4. If the remainder of the larger field does not contain all 
blanks and; 

If Sq > S 2 j then an A > C comparison condition exists. 

If ^2 ^ Si, then an A < C comparison condition exists. 

Comments : The result of the comparison is entered into the BCD condition 
register as described in the table below. If the fields are unequal, the next 
instruction is read from P + 3. If the fields are equal, the next instruction is 
read from P + 4. The count of the characters processed is placed in B^ regis¬ 
ter upon completion of the instruction. 


Comparison 

Condition 

Contents of BCR 

A = C 

OO2 

A > C 

OI2 

A < C 

IO2 
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CMP, DC 

Compare Field A fo 
Field C, Delimited 



23 


18 17 16 

00 

p 1 

67 

1 

r 


23 2120 1918 

1716 

00 

p + 1 

3 

Br 


S 

s 


23 


18 17 

12 

1 1 00 

P + 2 


M 


r 

DC 

^2 




22 

L_ 




r 


Br 


s 


Bs 

DC 

^2 


unmodified address of the highest 
order character in field A. 


R = r + (B^) 

index register flag for field A 

If B)- = 1, or 3, use index register B 

If Br = 2, use index register B^ 

If Br = 0, no indexing 
unmodified address of the highest 
order character in field C. 

S = s + (Bg) 

index register flag for field C (same 
bit functions as B ) 

6-bit delimiting character 

12-bit character count specifying the 

length of field C 


1 


Field A always contains the same number of charac¬ 
ters as field C during a delimited compare operation. 
Bits 18 through 23 of P + 2 should be loaded with 
zeros. 


Instruction Description: Compare characters in field A with field C proceeding 
from left to right. Terminate the operation when: 1) an unequal character com¬ 
parison occurs (the magnitudes of the unequal characters are noted - see table 
below), 2) all of the characters in the fields have been examined, 3) a character 
in either the A or C field equals the delimiting character. RNI at P + 3 for an 
unequal field comparison; RNI at P + 4 for an equal field comparison. 

3 

Comments: The count of the characters processed is placed in the B register 
upon completion of the instruction. The following table describes the state of the 
BDP Condition register when the operation is terminated; 


Terminating Comparison Condition 

Contents of BCR* 

A = C (through entire field or through 

C\ 

o 

o 

delimiting character) 


A >C 

012 

A < C 

102 
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Condition Test Instructions 


Operation Field 

Address Field 

Interpretation 

TMAV 77 

TST 67 

TSTN 67 


Test memory availability 

Test field A for sign 

Test field A for numeric 


TMAV 

Test 

Memory Availability 


23 le 17 1211 


00 


77 61 


0000 


Instruction Description: This instruction is used to test core storage for the 
presence of a particular address. 

Comments: Prior to executii^ this instruction, the lower 15 bits of the testing 
address must be formed in B^. The upper 3 bits of the address will be zeros 
unless the OSR has been previously selected by the (ROS) 55. 4 instruction. 

If a storage reply is received within 5 microseconds after executing the instruc¬ 
tion, the address does exist, and the next instruction is read from P + 2. If a 
reply does not occur within 5 microseconds, the address does not exist in the 
system and the next instruction is read from P + 1. The contents of the test 
address are not returned to the CPU and are of no consequence during the test. 



5-81 


Rev. D 













TSTN 

Test Field A for Numeric P 

P + 1 


P + 2 



r = unmodified address of the lowest 
order BCD character in field A 
R = r + (Bp 

B = index register flag for field A ^ 

If B = 1 or 3, use index register B 
If B^ = 2, use index register B^ 

If B*^ =0, no indexing 
= num?)er of BCD characters infield 
A to be tested. 

Bits 00 - 18 of P + 1, and bits 00 - 11 of 

P + 2 should be loaded with zeros. 

Instruction Description : Examine the sign character of field A and record the 
results in the BDP Condition register (see Comments). Field A is scanned 
from right to left until is exhausted. If the BCD Fault is not set upon 
completion of the instruction, field A is numeric. The BCD Fault can be 
sensed by instruction. 

Comments: If field A contains all zeros and the sign character is recognized as 
zero (contains BCD code of 60, 52, 40, 32, 20, 12, or 00), the Condition 
register is set to "0”. If field A does not equal zero, the Condition register is 
set as follows: 


Field A 

Contents of BDP 
Condition Register 

Positive - upper 2 bits of 

sign character are 

OOg, OI 2 , or 11^ 

OI 2 

Negative - upper 2 bits of 

sign character are 

IO 2 

IO 2 


A BCD fault is generated if one of the following conditions occur: 

1. Zone portion (upper 2 bits) of any character (except sign character) 
does not equal zero. 

2. Numeric portion (lower 4 bits) of any character contains a BCD code 
greater than llg, except the sign character where a 12g code is legal. 

3. The lowest orde^r character (sign character) contains a'72g code. 

Operation continues despite any BCD fault. 
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r - unmodified address of the lowest 
order BCD character in field A 
R = r + (Br) 

Bj, = index register flag for field A 

If Bj. = 1 or 3, use index register 
If Bj, = 2, use index register 
If Bp = 0, no indexing 
= number of BCD characters in field A 
to be tested 

Bits 00 through 18 of P + 1, and bits 00 through 
11 of P + 2 should be loaded with zeros. 

Instruction Description: Examine field A from right to left and determine if it 
is zero, greater than zero, or less than zero. The BDP Condition register is 
set to reflect the test results (see table below). The register is set to "00" if 
BCD codes of 52g, 40g, 32g, 20g, or 00 appear in the lowest order of field A 
when the remaining characters are zero. 

Comments: If field A contains all zeros and the sign character is recognized 
as zero (contains BCD code of 60, 52, 40, 32, 20, 12 or 00), the Condition 
register is set to "00". If field A does not equal zero, the Condition register 
is set as follows; 


Field A 

Contents of BDP 
Condition Register 

Positive - upper 2 bits of 

sign character are 

OOg, Olg, or llg 

Olg 

Negative - upper 2 bits of 

sign character are 

IO2 

lOg 


A BCD fault is generated if one of the following conditions occur: 

1. Zone portion (upper 2 bits) of any character (except sign character) does 
not equal zero. 

2. Numeric portion (lower 4 bits) of any character contains a BCD code 
greater than llg, except the sign character where a 12„ code is legal. 

3. The lowest orde^r character (sign character) contains a 7 2^ code. 

O 

Operation continues despite any BCD fault. 
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Sensing Instructions 


Operation Field 

Address Field 

Interpretation 

EXS 

77 

X, ch;x^0 

Sense external status 

COPY 

77 

X, ch;x=0 

Copy external status 

INTS 

77 

X, ch 

Sense interrupt 

INS 

77 

X, ch;x^0 

Sense internal status 

CINS 

77 

X, ch;x=0 

Copy internal status 


GEINERAL NOTES 

Refer to the ACI instruction for special considerations regarding the 'ch' desig¬ 
nator in these instructions. Refer to the SSIM instruction in the Interrupt group 
for a method of program testing for the presence of I/O channels in a system. 


EXS 

Sense 

External Status 


23 18 17 15 14 12 II 00 


77 

1 ^ 1 

1 1 

X 


ch = I/O channel designator, 0-7 
X = external status sensing mask code 
(see Comments below) 


Instruction Description: When a peripheral equipment controller is connected 
to an I/O channel by the CON (77.0) instruction, the EXS instruction can sense 
conditions within that controller. Twelve status lines run between each con¬ 
troller and its I/O channel. Each line may monitor one condition within the 
controller, and each controller has a unique set of line definitions. To sense a 
specific condition, a "1” is placed in the bit position of the status sensing mask 
that corresponds to the line number. When this instruction is recognized, RNI 
at address P + 1 if an external status line is active when its corresponding mask 
bit is "1". If no selected line is active, RNI at address P + 2. 

Comments : Refer to the 3000 Series Computer Systems Peripheral Equipment 
Codes manual (Pub. No. 60113400) for a complete list of status response codes. 


COPY 

Copy 

External Status 


23 18 17 15 14 12 II 00 


77 

1 ^ 1 

1 1 

0 0 0 0 


ch = I/O channel designator, 0-7 

Instruction Description: This instruction performs the following functions: 

1. The external status code from I/O channel ch is loaded into the lower 
12 bits of A. (See EXS instruction. ) 

2. The contents of the Interrupt Mask register are loaded into the upper 
12 bits of A. (See Table 5-3.) 

3. RNI from address P + 1. 
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TABLE 5-3. INTERRUPT MASK REGISTER BIT ASSIGNMENTS 


Masked Bit 
Positions 

Mask Codes (x) 

Interrupt Conditions Represented 

00 

0001 

I/O Channel 0 (includes interrupt gener- 

01 

0002 

1 ated within the channel 

02 

0004 

2 and external equipment 

03 

0010 

3 interrupts) 

04 

0020 

4 

05 

0040 

5 

06 

0100 

6 

07 

0200 

7 

08 

0400 

Real-time clock 

09 

1000 

Exponent overflow/underflow & BCD faults 

10 

2000 

Arithmetic overflow & divide faults 

11 

4000 

Search/Move completion 


/NTS 

Sense Interrupt 


23 18 17 15 14 12 II 00 


77 

4 

ch 

X 


ch = I/O channel designator, 0-7 
X = interrupt sensing mask code 

Instruction Description : Sense for the interrupt conditions listed in Table 5-4, 
RNI from P + 1 if an interrupt line is active and the corresponding sensing mask 
bit is a "1". If none of the selected lines are active, RNI from P + 2, Bits 
08-11 represent conditions that may be sensed without regard to channel desig¬ 
nation. 

TABLE 5-4. BIT ASSIGNMENTS FOR INTERRUPT SENSING CONDITIONS 


Mask Bit 
Positions 

Mask Codes (x) 

Interrupt Conditions Represented 


0001 

External equipment interrupt line 0 active 


0002 

1 


0004 

2 


0010 

3 

04 

0020 

4 

05 

0040 

5 

06 

0100 

6 

07 

0200 

7 

08 

0400 

*Real-time clock 

09 

1000 

^Exponent overflow/underflow & BCD faults 

10 

2000 

^Arithmetic overflow & divide faults 

11 

4000 

*Search/Move completion 


Internal faults are cleared as soon as they are sensed. 
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23 18 

17 15 

14 12 

il 00 


77 

1 ^ 1 

1 1 

X 


ch = I/O channel designator, 0-7 
X = internal status sensing mask code 

Instruction Description : Table 5-5 lists the bit definitions of the internal status 
sensing mask. Bits 00-04 and 06-07 represent conditions within I/O channel 
Bits 05 and 08-11, which represent internal faults, may be sensed without re¬ 
gard to channel designation. 

To sense a specific condition, load a ”1'' into the bit position of the mask that 
corresponds to the condition. When this instruction is executed, RNI from 
address P + 1 if an internal status line is active and the corresponding mask 
bit is a "1". If none of the selected lines is active, RNI from address P + 2. 


TABLE 5-5, INTERNAL STATUS SENSING MASK 


Mask Bit 
Positions 

Mask Codes (x) 

Condition Represented 


0001 

Parity error on channel ch 


0002 

Channel ch busy reading 


0004 

Channel ch busy writing 


0010 

External reject active on channel ch 

04 

0020 

No-response reject active on channel ch 

05 

0040 

*Illegal write 

06 

0100 

Channel ch preset by CON or SEL, but no 
reading or writing in progress 

07 

0200 

Internal I/O channel interrupt on channel 
ch upon; 

1) completion of read or write opera¬ 
tion, or 

2) end of record 

08 

0400 

^Exponent overflow/underflow fault (floating 
point) 

09 

1000 

^Arithmetic overflow fault (adder) 

10 


^Divide fault 

11 

4000 

*BCD fault 


Internal faults are cleared as soon as the condition is sensed. 
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23 


18 17 15 14 12 II 


00 



77 

1 ^ 1 

1 1 

00 00 


ch = I/O channel designator, 0-7 

Instruction Description: This instruction performs the following functions: 

1. The internal status code is loaded into the lower 12 bits of A, (See 
INS instruction.) 

2. The contents of the Interrupt Mask register are loaded into the upper 
12 bits of A. (See Table 5-3.) 

3. RNI from address P + 1. 
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Pause Instructions 


Operation Field 

Address Field 

Interpretation 

PAUS 77 

PRP 77 

X 

X 

Pause on condition 

Priority pause 


23 18 17 12 II 00 

PAus ;; ^ 

Pause --- 


X = pause sensing mask code 

Instruction Description: This instruction allows the program to halt for a max¬ 
imum of 40 ms if a condition (excluding typewriter - see note) defined by the 
pause sensing mask exists. (See Table 5-6.) If a "1" appears on a line that 
corresponds to a mask bit that is set, the count in P will not advance. If the 
advancement of P is delayed for more than 40 ms, the next instruction is read 
from address P + 1. If none of the lines being sensed are active,or if they be¬ 
come inactive during the pause, the program immediately skips to address 
P + 2. If an interrupt occurs and is enabled during a PAUS, the pause condition 
is terminated, the interrupt sequence is initiated and the address of the PAUS 
instruction is stored as the interrupted address. 

NOTE 

If either bit 08, 09 or 10 (or any combination of these bits) is set and 
the sensed condition exists, a pause will not occur and the instruc¬ 
tion at P + 1 is read up immediately. If these bit(s) are set but the 
condition(s) does not exist, the program immediately skips to P + 2. 

For all other bits, the normal PAUS routine is followed. TYPE 
FINISH and/or TYPE REPEAT are cleared if bit 9 and/or 10 are set 
and the sensed conditlon(s) does not exist. 


TABLE 5-6. PAUSE SENSING MASK 


Mask Bits 

Mask Codes 

Condition 

Notes 

00 

0001 

I/O channel 0 busy 

Channel read or write op- 

01 

0002 

1 

eration in progress, the 

02 

0004 

2 

External MC logic within 

03 

0010 

3 

the channel is set, or a 

04 

0020 

4 

Reply or Reject from a 

05 

0040 

5 

previous operation is still 

06 

0100 

6 

present at the channel 

07 

0200 

7 


08 

0400 

Typewriter busy 

Typewriter input or output 
in progress 

09 

1000 

Typewriter NOT 
finish 

Finish logic not set 

10 

2000 

Typewriter NOT 
repeat 

Repeat logic not set 

11 

4000 

Search/Move con¬ 
trol busy 

Search or Move operation 
in progress 
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23_ 18 17 _ 12 II _00 

77 61 X I 


X = pause sensing mask code 

Instruction Description : This instruction performs the same operation as the 
preceding PAUS (77. 6) instruction, however, the real-time clock is prevented 
from incrementing during the pause. 

Comments : Preventing the real-time clock from incrementing enables block 
control to continue an I/O operation without being referenced by the clock. 

This provides a more efficient I/O transfer operation. 


Priority Pause 
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Interrupt Instructions 


Operation Field 

Address Field 

Interpretation 

EINT 

77 


Enable interrupt control 

DINT 

77 


Disable interrupt control 

INCL 

77 

X 

Clear interrupt 

SSIM 

77 

X 

Selectively set interrupt mask 

SCIM 

77 

X 

Selectively clear interrupt mask 

CILO 

77 

cm 

Channel interrupt lockout 

SFPF 

77 


Set floating point fault 

SBCD 

77 


Set BCD fault 


E/NT 

Enable 

Interrupt Contiol 



Instruction Description: This instruction enables the interrupt control system. 

One additional instruction at P + 1 is executed before the processor is interrupted, 
provided that the additional instruction requires no more than one Read Address 
(RADR) cycle. If the EINT instruction is executed at P, the earliest possible 
interrupt will occur at P + 2. For an instruction containing more than one RADR 
cycle, the earliest possible interrupt can occur during its second RADR cycle. 

Comments ; Bits 00 through 11 shoixld be loaded with zeros. 


DINT 

Disable 

Interrupt Control 



Instruction Description: This instruction disables the interrupt control system. 
The system remains disabled until an EINT instruction is executed. Selected 
interrupts may still be sensed. 

Comments: Bits 00 through 11 should be loaded with zeros. 


INCL 

Clear Interrupt 


23 


12 M 


50 


X = interrupt mask register codes 


Instruction Description : This instruction clears the interrupt faults defined by 
the mask codes in Table 5-7. Internal I/O channel interrupts are cleared by this 
instruction and although the Interrupt Clear is sent to peripheral equipment, not 
all equipments drop their interrupt lines. Refer to the Peripheral Equipment 
Reference Manual, Pub. No. 60108800, for information of specific equipment. 
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TABLE 5-7. INTERRUPT MASK REGISTER BIT ASSIGNMENTS 


Mask Bit 
Positions 



Mask Codes (x) 

Interrupt Conditions Represented 


0001 

I/O Channel 0 (includes interrupts gener- 

01 

0002 

1 ated within the channel 


0004 

2 and external equipment 


0010 

3 interrupts) 

04 

0020 

4 

05 

0040 

5 

06 

0100 

6 

07 

0200 

7 

08 

0400 

Real-time clock 

09 

1000 

Exponent overflow/underflow & BCD faults 

10 

2000 

Arithmetic overflow & divide faults 

11 

4000 

Search/Move completion 


23_ IS 17 _ 12 II _ 00 

Selectively 77 52 x 

Set Interrupt Mask Register - 

X = interrupt mask register codes 

Instruction Description: This instruction selectively sets the Interrupt Mask 
register according to the interrupt mask code x.* For each bit set to "l" in x, 
the corresponding bit position in the Interrupt Mask register is set to "l" (see 
Table 5-7), Bit positions representing non-existent I/O channels cannot be set. 

Comments : A program test for the existence of I/O channels for a system is 
as follows: 

1. Set the interrupt mask bits to all "l"s by executing a SSIM 
(77 5 27777) instruction. 

2. Execute either a COPY or CINS instruction and examine the 
upper 12 bits of A. 

3. As bits representing non-existent I/O channels cannot be set, a 
" 0 ” in bits 00-07 of the Interrupt Mask register indicates a non¬ 
existent I/O channel. 


23_ 18 17 _ 12 II _00 

7 7 53 X I 


X = interrupt mask register codes 

Instruction Description: This instruction selectively clears the Interrupt Mask 
register according to the interrupt mask code x.* For each bit set to "l” in x, 
the corresponding bit position in the Interrupt Mask register is set to "O" (see 
Table 5-7). 


SCIM 

Selectively Clear 
Interrupt Mask Register 


*The Interrupt Mask register must not be set or cleared while the interrupt system 
is enabled to prevent extraneous interrupts from occuring. 


Rev. A 


5-90 
















CILO 

Channel Interrupt Lockout 


12 I I 10090807 


in 


cm 


cm = channel mask 


Bits 08 and 11 should be loaded with zeros. 

Instruction Description: Disables all external interrupts on channel(s) cm while 
the channel(s) are busy. Termination of the I/O operation clears the disabling 
function. 

Comments : Bit 00 corresponds to channel 0, bit 01 corresponds to channel 1, etc. 
More than one channel may be set to ”1" for multiple channel interrupt lockout. 

The mask is cleared by termination of the I/O operation, by clearing the channel(s), 
and by a Negate Channel Interrupt Lockout signal from certain peripherals. 


SFPF 

Set Floating 
Point Fault 


23 18 17 12-11 00 



Instruction Description: The floating point fault logic sets when a floating point 
fault occurs. This instruction is used when the optional floating point arithme¬ 
tic logic is not present in a system. An interpretive software routine should 
recognize any conditions which would have caused a fault if the operation had 
been executed by the optional hardware. 

Comments: Bits 00 through 11 should be loaded with zeros. 


SBCD 

Set BCD Fault 



Instruction Description: The BCD fault logic sets when a BCD fault occurs. 
This instruction is used when the optional BCD arithmetic is not present in a 
system. An interpretive software routine should recognize any condition which 
would have caused a fault if the operation had been executed by the optional 
hardware. 

Comments: Bits 00 through 11 should be loaded with zeros. 


5-91 


Rev. C 














Input/Output Instructions 


Operation Field 

Address Field 

Interpretation 

CLCA 

77 

cm 

Clear I/O channel(s) 

lOCL 

77 

X 

Clear I/O channel(s) and equipment 

CON 

77 

X, ch 

Connect to external equipment 

SEL 

77 

X, ch 

Select function 

CTI 

77 


Set console typewriter input 

CTO 

77 


Set console typewriter output 

IN PC, INT, 

73 



B,H,G 


ch, r, s 

Character-Addressed Input to storage 

INAC, INT 

73 

ch 

Character-Addressed Input to A 

INPW, INT, 

74 


b,n,g 


ch, m, n 

Word-Addressed Input to storage 

INAW, INT 

74 

ch 

Word-Addressed Input to A 

OUTC, INT, 

75 


B,H 


ch, r, s 

Character-Addressed Output from 
storage 

OTAC, INT 

75 

ch 

Character-Addressed Output from A 

OUTW, INT, 

76 


B,N 


ch, m, n 

Word-Addressed Output from storage 

OTAW, INT 

76 

ch 

Word-Addressed Output from A 


Unlike I/O operations with A, I/O instructions with storage are buffered. As soon 
as Read or Write signals are activated^ Main Control relinquishes control of the 
storage I/O operation and returns to the main program. 

Registers 00 through 11 q of the Register File are reserved for I/O operations. 
Registers 00 through 07 are used for storing the modified instruction words con¬ 
taining the current character addresses. (Refer to Table 5-8). Registers lOg 
through 17 hold the modified sub-instruction words containing the last character 
addresses (+ 1 depending upon the instruction parameters). In cases where 
addresses require modification to obtain dynamic I/O operations, care should be 
exercised to provide proper readout and restoration of the modified control bits. 

During the execution of word addressed storage I/O instructions, the addresses 
'm' and 'n' are shifted left two bit positions. From this time on and when they 
are stored in the Register File, they are recognized as character addresses. 

Before executing an I/O instruction in Executive mode, the desired program state 
number (0 through 7) must be loaded into the lower three bits of the A register. 

The program state number is automatically transferred to the upper digit of Reg¬ 
ister File location OX for referencing during buffered I/O tasks, thus enabling the 
A register to be used for other operations. 

Table 5-8 and its accompanying example illustrate the relationship between the 
Register File addresses, their contents, and the individual instructions. Each 
I/O instruction should be referenced for a description of its particular parameters 
and a flowchart of the overall operation. The ACI instruction, described else¬ 
where in this section, should be consulted for special I/O channel considerations. 
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When performing I/O operations with peripheral equipment not equipped with a 
12 to 6-bit disassembly feature, character oriented instructions should not be 
used, thus preventing erroneous transmission parity errors. 


TABLE 5-8. MODIFIED I/O INSTRUCTION WORDS 


1 

Instruction 

Relative location 

of instruction words 

(See individual instructions) 

Register 

File 

location 

Contents of Register 
File location 


73 (INPC) 

P 

IX 

3 - 



P + 1 

OX 

♦.c 

n' — — — — — 

5 w) 





2 ^ 

74 (INPW) 

P 

IX 

0 - 

o 


P + 1 

OX 

nr — — — — — — — 

g m 






75 (OUTC) 

P 

IX 

1- 

og 


P+ 1 

ox 

Ox 

X|V — — — — — — — 

l> 

76 (OUTW) 

P 

IX 

2- 



P + 1 

ox 

-^r - — — — — — — 



P 

IX 

7- 


73 (INAC) 

P + 1 

ox 


a 


P 

IX 

4 - 

.2 < 

74 (INAW) 

P + 1 

ox 


ni Xi 







P 

IX 

5 - 

o 

75 (OTAC) 

P + 1 

ox 




P 

IX 

6- 


76 (OTAW) 

P + 1 

ox 

_^_ 


X = An I/O channel designator "ch", 0, 1, 2, 3, 4, 5, 6, or 
* = The program number (lowest 3 bits of the 'A' Register) 


V. \ 


Upper digit position 
(Blanks indicate 
digits unaltered by 
control logic) 


EXAMPLE: 


Execute the following INPW instruction. 


P = 74 003200 

P + 1 = 20 003100 
P + 2 = 01 003300 


(A) = 00000001 

3306 I/O Channel 


ANALYSIS: I/O Channel 2 is specified; thus Register File location 12 is 
used to store 04015000 and location 02 holds 10014400. 


This instruction specifies 12- to 24-bit assembly, no interrupt 
upon completion, forward storage, and an unconditional jump 
to address 03300 as a reject instruction. 
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The first word address (m) of the block of storage assigned to 
receive data from an external equipment is m = 03100. 

The last word address (n) of the assigned storage area (plus 
one) is n = 03200. 

The first 12-bit byte is stored in bits 12 through 23 at address 
003100, the second byte in bits 00 through 11, etc. 


CLCA 

Clear Channel Activity 


12 I I 10090807 


d 


cm 


cm = channel mask 

Bits 08 and 11 should be loaded with zeros. 
Instruction Description : Clear only the selected I/O channel(s). 

Comments : The peripheral equipment associated with the selected channel(s) 
are not cleared by executing this instruction. Bit 00 corresponds to channel 0, 
bit 01 corresponds to channel 1, etc. More than one channel may be set to "1" 
for multiple channel clearing. 


23_1817_1211_00 

77 51 X 


lOCL 

Clear IfO, Typewriter, 
and SearchiMove 


x = block control clearing mask 

Instruction Description: This instruction may be used to clear the I/O channels. 
It also clears all associated peripheral equipment, the typewriter or the Search/ 
Move control according to bits set in the Block Control clearing mask. (See 
Table 5 -9.) 
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TABLE 5-9. BLOCK CONTROL CLEARING MASK 


Mask Bits 

Mask Codes (x) 

Controls Cleared 

00 

0001 

I/O channel 0 

01 

0002 

1 

02 

0004 

2 

03 

0010 

3 

04 

0020 

4 

05 

0040 

5 

06 

0100 

6 

07 

0200 

7 

08 

0400 

Typewriter 

09 

1000 

(see note) 

10 

2000 

(see note) 

11 

4000 

Search/Move 


NOTE 

If bits 09 and 10 are both set or both clear, the channel(s) specified by- 
bits 00 through 07 of the mask are cleared, i. e,, Read or Write, Status, 
and Channel Interrupt are cleared, A 5. 5 usee Clear signal is also 
sent to the peripheral equipment and controllers connected to the selected 
channel(s). 

If bit 09 is clear and bit 10 is set, the instruction will clear the 
channel(s) only and the 5,5 usee Clear signal is not transmitted. Bit 
08 clears the typewriter as well as the Type Load or Type Dump logic 
in Block Control, 


CON 

Connect 


23 18 

17 15 

14 12 

11 00 

77 

1 ^ 1 

1 

X 


ch = I/O channel designator, 0-7 
X = 12 bit connect code. Bits 09-11 

select one of eight controllers which 
may be attached to channel ch. Bits 
00-08 select the peripheral units 
connected to the controller. 

Instruction Description: This instruction sends a 12-bit connect code along with 
a connect enable to an external equipment controller on I/O channel ch. If a 
Reply is received from the controller within 100 usee, the next instruction is 
read from address P + 2. If a Reject is received or there is no response within 
100 usee, a reject instruction is read from address P + 1. If the I/O channel is 
busy, a reject instruction is read from address P + 1. 


5-95.0 


Rev. B 












Figure 5-6. 1. 77 Connect Operat 

















ch = I/O channel designatoi.-, 0-7 
X = 12-bit function code. Each piece of 
external equipment has a unique set 
of function codes to specify opera¬ 
tions within that device. Refer to 
the 3000 Series Computer Systems 
Peripheral Equipment Codes Publi¬ 
cation No. 60113400 for a complete 
list of function codes. 

Instruction Description : This instruction sends a 12-bit function code along 
with a function enable to the unit connected to 1/O channel ch. If a Reply is re¬ 
ceived from the unit within 100 usee, the next instruction is read from P + 2. 

If a Reject is received or there is no response within 100 usee, or if the I/O 
channel is busy, a reject instruction is read from address P + 1. 

The following conditions or combination of conditions result in a Reject: 

1) No Unit or Equipment Connected: The referenced device is not connected 
to the system and cannot recognize a Select Function instruction. If no 
response is received within 100 usee, the Reject signal is generated 
automatically by the I/O channel, 

2) Undefined Code: When the Function code x is not defined for the specific 
device, a Reject may be generated by the device. However, in some 
cases an undefined code will cause the device to generate a Reply although 
no operation is performed. (Refer to the reference manual pertaining to 
the specific peripheral device.) 

3) Equipment or Unit Busy or Not Ready: The device cannot perform the 
operation specified by the function code x without damaging the equipment 
or losing data. For example, a Write End of File code is rejected by a 
tape unit if the tape unit is rewinding. 

4) Channel Busy: The selected data channel is currently performing a Read 
or Write operation or a Reply or Reject from a previous operation is still 
present at the channel. 
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CTI 

Sef Console 
Typewriter Input 



Bits 00 through 11 should be loaded with zeros. 

Instruction Description: This instruction, like the TYPE LOAD switch, permits 
a block of data to be entered into storage as soon as the TYPE LOAD indicator 
lights. If a block of data smaller than the one defined by registers 23 and 33 is 
to be typed, the FINISH switch should be depressed when the typing is completed. 
If more data is entered than the defined block can hold, the excess data is lost. 

If a typing error occurs, the REPEAT button should be depressed. When either 
the FINISH or REPEAT switch is depressedi the typewriter input operation 
is terminated and the appropriate status Dits (09 and 10) may be sensed with the 
PAUS instruction. (For additional information refer to the PAUS instruction.) 


CTO 

Set Console 
Typewriter Output 



Bits 00 through 11 should be loaded with zeros. 

Instruction Description: This instruction, like the TYPE DUMP switch, causes 
the typewriter to print out the block of data defined by the character addresses 
in registers 23 and 33. 


NOTE 

The CTI and CTO instructions are mutually exclusive. Typewriter busy 
should be checked before these instructions are used and before registers 
23 and 33 are altered. 
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INPC 

C haractsr-Addressed 
Input to Storage 


P 

P + 1 


23 


23 21 

20 19 18 

17 

» —■ 1 

16 00 

1 1 

G 



0 
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B = "1" for backward storage 
ch = I/O channel designator, 0-7 
H = "0" for 6- to 24-bit assembly 
H = "1" for 12- to 24-bit assembly 
INT = "1" for interrupt upon completion 
r = first character address of I/O data 
block; becomes current address as 
I/O operation progresses 
s = last character address of input data 
block, plus one (minus one, for back¬ 
ward storage) 

G = ''1'' for word count control 

Instruction Description: This instruction transfers a character address block 
of data, consisting of 6-bit characters or 12-bit bytes, from an external equip¬ 
ment to storage. During 6- to 24-bit assembly (H = 0), the lower 6 bits of suc¬ 
cessive data words (12-bit data words from the 3306, 24-bit data words from the 
3307) are loaded into successive characters in storage, the first character being 
loaded into character address r. The next character is loaded into character 
address (r + 1) if doing forward storage (B = 0), into (r - 1) if doing backward 
storage (B = 1), During 12- to 24-bit assembly (H = 1), successive 12-bit bytes 
are loaded into successive halves of storage words. The first byte will be loaded 
into the upper or lower half of the storage word, depending upon character address 
r. If B = 0, the next byte is loaded into (r + 2); if B = 1, the next byte is loaded 
into (r - 2), During 12- to 24-bit assembly, the lowest bit of each character add¬ 
ress is forced to remain a "0" in register OX. This ensures that assembled bytes 
are in either the upper or the lower half of the word being stored. 

If channel 'ch' is not busy, the buffered I/O operation with storage commences 
while Main Control performs an RNI at P 4- 3. Main Control continues executing 
the main program while the I/O operation occurs simultaneously. If channel 'ch' 
is initially busy. Main Control performs an RNI at P +2 and the I/O operation 
does not occur. 


NOTES 

When bit 20 of the subinstruction word at P + 1 is "1", the word 
count control feature allows this I/O operation to continue beyond 
an End-of-Record signal. In practice, when an End-of-Record 
signal is sent, the Read line drops but the buffer operation does 
not terminate. The Read signal sent to the external equipment then 
reappears until the word count is satisfied. This signal appears as 
a new input instruction to the external equipment, but as a continue 
Read to the I/O channel. 

If H = "1", an even character count must be used. If the count is 
odd, the last character will be lost. 
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Activate Read 
On I/O 
Channel O-*? 


Load . 
(P+1) ^ Z 


Load . 
(P)- 


' ^—I—^ 

Yes 
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P + 2 
(Reject) 
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store (P+l) 
In One Register 
(00 ^ 07) 
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Terminate 

Input 
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INPW 


Word-Addressed 

P 

Input to Storage 


P + 1 


23 18 17 16 15 14 00 



n 

^777 


74 
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23 2120 1918 17 16 15 14 00 


1 1 

H 


N 



m 

1 1 

□ 

□ 

□ 





B = "1" for backward storage 
ch = I/O channel designator, 0-7 
INT = ”1" for interrupt upon completion 
N = "0" for 12- to 24-bit assembly 
N = "1" for no assembly 
m = first word address of I/O data block; 
becomes current address as I/O 
operation progresses 
n = last word address of input data block, 
plus one (minus one, for backward 
storage) 

G = "1" for word count control 

Bits 15 and 16 at P and P + 1 should be 

loaded with zeros. 

Instruction Description: This instruction transfers a word-addressed data block 
from an external equipment to storage. Transferring 12-bit bytes or 24-bit 
words depends upon the type of I/O channel used. The 3306 utilizes 12-bit bytes 
and the 3307 uses 24-bit words. 

During forward storage and 12- to 24-bit assembly, the first byte of a block of 
data is stored in the upper half of the memory location specified by the storage 
address. Conversely, during backward storage, the first byte is stored in the 
lower half of the memory location. 

If channel 'ch' is not busy, the buffered I/O operation with storage commences 
while Main Control performs an RNI at P + 3. Main Control continues executing the 
main program while the I/O operation occurs simultaneously. If channel 'ch' is 
initially busy. Main Control performs an RM at P + 2 and the I/O operation does 
not occur. 


NOTES 

When bit 20 of the subinstruction word at P + 1 is "1", the word count 
control feature allows this I/O operation to continue beyond an End-of- 
Record signal. In practice, when an End-of-Record signal is sent, the 
Read line drops but the buffer operation does not terminate. The Read 
signal sent to the external equipment then reappears until the word 
count is satisfied. This signal appears as a new input instruction to the 
external equipment, but as a continue Read to the I/O channel. 

If N = 1 and a 3306 is used, the upper 12 bits of each storage word will 
be unchanged. If N = 1 and a 3307 is used with a 12-bit device, the upper 
12 bits will be zeros. 
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Figure 5-8. 74 I/O Operation with Storage 
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B = "1" for backward storage 
ch = I/O channel designator, 0-7 
H = ”0" for 24- to 6-bit disassembly 
H = "1" for 24- to 12-bit disassembly 
INT = "1” for interrupt upon completion 
r = first character address of I/O data 
block; becomes current address as 
I/O operation progresses 
s = last character address of output data 
block, plus one (minus one, for back¬ 
ward output) 

Bit 20 at P + 1 should be loaded with a "O" 


Instruction Description: This instruction transfers a character-addressed block 
of data, consisting of 6-bit characters or 12-bit bytes, from storage to an exter¬ 
nal equipment. During 24- to 6-bit disassembly (H = 0), the first character is 
transferred from character address r. The next character is transferred from 
(r + 1) if forward storage (B = 0), from (r - 1) if backward storage (B = 1). Dur¬ 
ing 24- to 12-bit disassembly (H = 1), the first byte will be transferred from the 
upper or lower half of the storage word, depending upon character address r. If 
B = 0, the next byte is transferred from (r + 2); if B = 1, the next byte is trans¬ 
ferred from (r - 2). 

If channel 'ch' is not busy, the buffered I/O operation with storage commences 
while Main Control performs an RNI at P + 3. Main Control continues executing 
the main program while the I/O operation occurs simultaneously. If channel 'ch' 
is initially busy. Main Control performs an RNI at P + 2 and the I/O operation 
does not occur. 


NOTE 

If H = "1", an even character count must be used. If the count is odd, 
the last character will be lost. 
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Figure 5-9, 75 I/O Operation with Storage 




















23 (8 17 16 15 14 00 


B = ”1" for backward storage 
ch = I/O channel designator, 0-7 
INT = "1" for interrupt upon completion 
m = first word address of I/O data block; 
becomes current address as I/O 
operation progresses 
N = "O” for 24- to 12-bit disassembly 
N = "1" for straight 12- or 24-bit data 
transfer 

n = last word address of output data block, 
plus one (minus one, for backward 
output) 

Bits 15 and 16 at P and bits 15,16,and 20 of 
P + 1 should be loaded with zeros. 

Instruction Description: This instruction transfers a word-addressed block of 
data consisting of 12-bit bytes or 24-bit words from storage to an external 
equipment. 

With no disassembly, 12 or 24-bit transfer capability depends upon whether a 
3306 or 3307 I/O channel is used. If an attempt is made to send a 24-bit word 
over a 3306 I/O channel, the upper byte will be lost. 

If channel 'ch' is not busy, the buffered I/O operation with storage commences 
while Main Control performs an RNI at P + 3. Main Control continues executing 
the main program while the I/O operation occurs simultaneously. If channel 'ch' 
is initially busy. Main Control performs an RNI at P + 2 and the I/O operation 
does not occur. 
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ch = I/O channel designator, 0-7 
INT = "1" for interrupt upon completion 

Bits 00 through 16 at P and P + 1 should be loaded 
with zeros. 

Instruction Description : This instruction transfers a 12-bit byte into the lower 
12 bits of A or a 24-bit word into all of A from an external equipment. Trans¬ 
ferring 12 or 24 bits depends upon whether a 3306 or 3307 I/O channel is used. 
(A) is cleared prior to loading and, in the case of a 12-bit input, the upper 12 
bits remain cleared. When the I/O operation with A is completed, RNI at P + 3 
If channel 'ch' is busy and the operation cannot be performed, RNI at P + 2, 

NOTE 

Bits 18, 19, and 20 may be all "O's" when a 3306 Data 
Channel is used. However, when bit 18 = "1", bit 19 = "0" 
or "1", and bit 20 = "0", this instruction can be used with 
either a 3306 or 3307 (when the 12- to 24-bit assembly feature 
is not utilized). This eliminates the need to alter a program 
when a 3307 is selected in place of a 3306 or vice versa. 

If the assembly feature of the 3307 is utilized, bits 18, 19, 
and 20 take on the following significance: 

• For 12- to 24-bit forward assembly, bits 18, 19, and 20 = 0 

• For 12- to 24-bit backward assembly, bits 18, 19, and 20 = 2 
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Figure 5-12. 74 I/O Operation with A 
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OTAC 

Ouiput 

Character from A 



ch = I/O channel designator, 0-7 
INT = "1” for interrupt upon completion 

Bits 00 through 16 at P and P + 1 should be loaded 
with zeros. 

Instruction Description: This instruction transfers a character from the lower 
6 bits of A to an external equipment. The original (A) are retained. When the 
I/O operation with A is completed, RNI at P + 3. If channel 'ch' is busy and the 
operation cannot be performed, RNI at P + 2. 



Figure 5-13. 75 I/O Operation with A 
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ch = I/O channel designator, 0-7 
INT = "1” for interrupt upon completion 

Bits 00 through 16 at P and P + 1 should be loaded 
with zeros. 

Instruction Description : This instruction transfers the lower 12 bits of A or 
(A) to an external equipment, depending upon the type of I/O channel (3306 or 
3307) that is used. The original (A) remain unchanged. When the I/O operation 
with A is completed, RNI at P + 3. If channel 'ch' is busy and the operation 
cannot be performed, RNI at P + 2. 


NOTE 

Bits 18, 19, and 20 may be all "O's" when a 3306 Data 
Channel is used. However, when bit 18 = "1", bit 19 = "0" 
or "1", and bit 20 = "0", this instruction can be used with 
either a 3306 or 3307 (when the 24- to 12-bit disassembly 
feature is not utilized). This eliminates the need to alter 
a program when a 3307 is selected in place of a 3306, or 
vice versa. 

If the disassembly feature of the 3307 is utilized, bits 18, 

19, and 20 take on the following significance: 

• For 24- to 12-bit forward disassembly, bits 18, 19, and 20 = 2 

• For 24- to 12-bit backward disassembly, bits 18, 19, and 20 = 0 
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X = I/O Channel CH (0-7) 


Figure 5-14. 76 I/O Operation with A 
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Relocation Control Instructions 


Operation Field 

Address Field 

Interpretation 

RIS 55 

ROS 55 

SBJP 77 


Relocate with (ISR) 

Relocate with (OSR) 

Set boundary jump 


RIS 

Relocate 

with Instruction State 


23 IB 17 15 14 00 



Bits 00 through 14 should be loaded with zeros. 

Instruction Description : Clear bit 02 of the Condition register, enabling (ISR) to 
be used as the upper 3 bits of address for all storage references during Program 
State. 

Comments: A Master Clear produces the same effect as this instruction. 


ROS 


23 18 

17 15 

14 

00 

Relocate with 


55 

4 



Operand State 







Bits 00 through 14 should be loaded with zeros. 
Instruction Description: Set bit 02 of the Condition register, enabling (OSR) to 
be used as the upper 3 bits of address for all operand references in Executive 
mode. 

f 1 

Comments : Refer to Interrupts During Executive Mode in Section 4 for 
additional information. 


SBJP 

Set 

Boundary Jump 


23 18 17 12 II 


00 


77 62 


0 0 0 0 


Instruction Description : Set a boundary jump condition flag (bit 00 of the condi- 
tion register). 

Comment : After this instruction is executed, the next jump instruction senses 
the flag and causes the instruction to reference the ISR for relocation. When the 
jump instruction is executed, the boundary jump condition flag is cleared and the 
Program State is set. 

Refer to 'Interrupts During Executive Mode' in Section 4 for additional infor¬ 
mation. 
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Multiprocessing Control Instructions 


Operation Field 

Address Field 

Interpretation 

lAPR 77 

SDL 77 


Interrupt associated processor 

Set destructive Load condition 


lAPR 

Interrupt 

Associated Processor 



Bits 00 through 11 should be loaded with zeros. 

Instruction Description : The processor (computer) executing this instruction 
sends an interrupt to an associated processor via a special cable. The inter¬ 
rupt remains active in the receiving computer until it is recognized. 


SDL 

Set 

Destructive Load 


23 18 17 12 II 09 08 00 

77 

62 

1 ^ 1 

[ 0 0 0 


Instruction Description: Set the destructive load condition flag (bit 01 of the CR). 

Comments : After this instruction is executed, the next Load A (LDA) instruc¬ 
tion senses the flag and causes the following operations to occur; 

1. Load (M) from LDA instruction into A and restore 77777777 into 
(M). 

2. Clear the destructive load condition flag when executing the LDA 
instruction. 

Refer to 'Interrupts During Executive Mode' in Section 4 for additional infor¬ 
mation. 

This instruction is useful in controlling multiple CPU's during multi-processing 
instructions. 
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Conversion Instructions 


Operation Field 

Address Field 

Interpretation 

CVDB 66 

CVBD 66 

DTA 66 

DTA,DC 66 

ATD 66 

ATD,DC 66 

PAK 66 

UPAK 66 

r, B],, S1, m, Bj^ 

^ > -^m > > ^n 
r, Br, S2.m;Bm 
r. Bp, 

S2. s, Bg 
m, B^, S2 j s, Bg 
r. Bp, S2, m, BpQ 

Convert BCD field to binary field 
Convert binary field to BCD field 
Convert BCD field to ASCII field 
Convert BCD field to ASCII, delimiting 
Convert ASCII field to BCD field 
Convert ASCII field to BCD, delimiting 
Convert 6-bit BCD to 4-bit BCD 

Convert 4-bit BCD to 6-bit BCD 
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CVDB 
Convert , 
BCD to Binary 


23 18 1716 00 

P 

P + 1 

P + 2 



r = unmodified address of the highest order 
BCD character in field A. R = r + [ Br-] 

Bj;. = index register flag for field A. 

If Bj, = 1 or 3, use index register B'^ 

If Bj. = 2, use index register B^ 

If B^ = 0, no indexing 

m = unmodified address of the highest order 
bits in binary field C. M = m + [ Bml 
B = index register flag for binary field C. 

(same bit functions as B ). Bits 02-14 
of the index register are used for word 
address indexing (13 bit index-sign 
extended). Bits 00 and 01 must be set 
to "I's". 

Sj = number of BCD characters to be con¬ 
verted. 

Bits 00 and 01 of P + 1, and bits 00 through 11 of 
P + 2 should be loaded with zeros. 

Instruction Description: Convert a BCD number of up to 14 ]^q numeric characters 
in magnitude (including sign) into its binary equivalent in one's complement no¬ 
tation and store the result in locations M and M + 1. 

Comments: The resultant binary number is placed into the words at locations M 
and M + 1. The sign of the binary number is always stored in bit 23 of M and the 
sign of the original BCD number is located in the upper 2 bits of the lowest order 
character in field A. The maximum positive BCD number (fourteen 9's) is equal 
to 26571420364377773. The complement of this number in M and M + 1 equals a 
negative field of fourteen 9's. 

3 

The BDP Condition register is set to the sign of field A, The B register contains 
a count of the BCD characters converted. 

A BCD fault is generated if one of the following conditions occur: 

1. Zone portion (upper 2 bits) of any character (except sign character) does 
not equal zero. 

2. Numeric portion (lower 4 bits) of any character in field A contains a BCD 
code greater than llg, except the sign character where a 12g code is legal. 

3. The lowest order character (sign character) contains a 72g code. 

4. More than 142^g BCD characters are specified by S 

Operation continues despite any BCD fault. 
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CV8D 
Convert 
Binary to BCD 


P 


P + 1 


P + 2 

m = unmodified address of the highest or¬ 
der bits in binary field A. 

M = m+ [Bjn] 

Bm = index register flag for field A. ^ 

If B^ = 1 or 3, use index register B 
H Bj^ = 2, use index register B^ 

If B^ = 0, no indexing 



Bits 02-14 of the index register are used for word address 
indexing (13 bit index-sign extended). Bits 00 and 01 
must be set to "I's". 


n = immodified address of the highest or¬ 
der BCD character in field C. 

N = n+ [Bn] 

Bn = index register flag for field C. 

(same bit functions as Bm) 

Bits 00 and 01 of P, bits 00 and 01 of P + 1, and bits 00 
through 23 of P + 2 should be loaded with zeros. 

Instruction Description: Convert the 48-bit binary number (including sign) at M 
and M + 1 into its signed, numeric BCD equivalent and store in field C, 


Comments: (M) and (M + 1) are always analyzed for the binary number to be con¬ 
verted. This is true even if the binary number does not utilize all of the bit posi¬ 
tions of M. The sign of the binary number is stored in the upper two bits of the 
lowest order BCD character in field C and is set in the BDP Condition register. 
The sign of the original binary number is located in bit 23 of M. (Refer to Appen¬ 
dix B and F for additional BCD information.) 


A BCD fault is generated if the conversion results in a number of more than 14 jq 
BCD characters. However the lower 14 j^q characters will be correct. 


BCD character positions 
appear in this order. 
(This character position 
always contains the sign 
of the field.) 


Highest Order BCD 
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23 


18 17 16 


00 


DTA 
Convert 
BCD to ASCII 



r = unmodified address of the highest or¬ 
der character in BCD field A, 

R = r + [ B^] 

Bj. = index register flag for field A. 

If Bp = 1 or 3, use index register B^ 

If Bp = 2, use index register B^ 

If Bp = 0, no indexing 

m = unmodified word address of the highest 
order characters in ASCII field C. 

M = m + [ Bm] 

B = index register flag for field C 

(same bit functions as Bp . Bits 
02-14 of the index registW are 
used for word address indexing (13 
bit index-sign extended). Bits 00 
and 01 must be set to s". 

S 2 = number of characters to be converted 

Bits 00 and 01 at P + 1 and bits 12 - 23 of 

P + 2 should be loaded with zeros. 

Instruction Description : Convert a field of up to 4095 6-bit BCD characters in 
field A into the 8-bit American Standard Code for Information Interchange 
(ASCII) in field C. 

Comments: Conversion proceeds from left to right (Refer to Appendix A for a 
comparative listing of BCD and ASCII codes.) 


If the last ASCII character stored occupies bits 12-19, zeros are stored in bits 
00-07. The BCD codes of 12g, 32g, and 52g are not treated as zero for this 
instruction. The count in the B^ register upon completion equals four times the 
number of store cycles. The BDP Condition register is set to the sign of field A. 


The first ASCII character is 
specified by M. 


always placed in this character position of the word 


M 

M + 1 



|o 0 0 0 

FIRST ASCII 
CHARACTER 

0 0 0 0 

SECOND ASCII 
CHARACTER 

23 20 

19 12 II 08 07 00 

|o 0 0 0 

THIRD ASCII 
CHARACTER 

0 0 0 0 

FOURTH ASCII 
CHARACTER 
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23 


18 17 16 


00 


DTA, DC 
Convert BCD 
to ASCII, Delimited 


P 

P + 1 

P + 2 



r = unmodified address of the highest or¬ 
der character in BCD field A. 

R = r + [ Bj.]. 

Bj- = index register flag for field A 

If Bj, = 1 or 3, use index register B^ 

If Bj, = 2, use index register B^ 

If Bj, = 0, no indexing 
m = unmodified address of the highest or¬ 
der word in ASCII field C. 

M = m + [ Bjn] 

B = index register flag for field C 

(same bit functions as B ). Bits 
02-14 of the index register are used 
for word address indexing (13-bit 
index-sign extended). Bits 00 and 
01 must be set to ones. 

S 2 = number of characters in ASCII field C 

DC = 6-bit delimiting character compared 
against characters in field A. 

Bits 18 through 23 at P + 2 and 00 and 01 at P + 1 
should be loaded with zeros. 


Instruction Description: Convert a field of up to 4095 6-bit BCD characters in 
field A into the 8-bit American Standard Code for Information Interchange (ASCII) 
in field C. The conversion proceeds from left to right. The operation is termin¬ 
ated when the number of characters specified byS 2 ha-S been converted or the 
delimiting character is recognized in field A. A character equal to the delimiting 
character is converted when encountered. 


Comments: The BCD codes of 12g, 32g, and 52g are not treated as zero for this 
instruction. The count in the B^ register upon completion equals four times the 
number of store cycles. 


The first ASCII character is always placed in this character position of the wore 
specified by M. 


23 20 19 


08 07 


00 


M 


M + 1 


0 0 0 0 

FIRST ASCTI 
CHARACTER 

0 0 0 0 

SECOND ASCII 
CHARACTER 

23 20 

19 12 

II 08 07 00 

0 0 0 0 

THIRD ASCII 
CHARACTER 

0 0 0 0 

FOURTH ASCII 
CHARACTER 
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p 


p + 1 


P + 2 

m = unmodified word address of the highest 
order characters in ASCII field A. 

M=m + (Refer to diagram below.) 

B = index register flag for field A ^ 

If B = 1 or 3, use index register B'^ 
if = 2, use index register B^ 

If B^ =0, no indexing 
Bits^2-14 of the index register are 
used for word address indexing (13-bit 
index-sign extended). . Bits 00 and 01 
must be set to ones. 

s = unmodified address of the highest order 
character in BCD field C. S = [s + Bs] 
Bg = index register flag for field C 
(same bit functions as Bj^^) 

§2 = number of characters in BCD field C 

Bits 00 and 01 of P and bits 12-23 of P + 2 should be 
loaded with zeros. 


Instruction Description: Convert a field of up to 4095 8-bit American Standard 
Code for Information Interchange (ASCII) characters in field A into 6-bit BCD 
characters in field C. The conversion proceeds from left to right. The operation 
is terminated when §2 is exhausted. 

Comments: A BCD fault is generated if bit positions 05 and 06 for any character 
contain both "I's" or both "O's" (an illegal character). An illegal character is set 
to zero in field C and conversion continues to completion. The register indi¬ 
cates the number of BCD characters stored. 

The first ASCII character is always located in this character position of the word 
specified by M. Shaded areas are not used. 


23 20 19 ♦ 12 II 08 07 00 

M 


M + 1 

I I 

I I 

etc. etc. 
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23 


18 1716 


ATD, DC 
Convert ASCII 
to BCD, Delimited 


P 

P + 1 

P + 2 


02 01 00 


66 

1 

m 

1 

23 2120 1918 

1716 


00 

1 3 1 

B 

! 

m 

Bs 

s 

23 

2019 



12 1 1 

00 


DC 

S 2 


m = unmodified word address of the highest 
order characters in ASCII field A. 
(Refer to diagram below. ) 

M = m + 

B = index register flag for field A ^ 

^ If B = 1 or 3, use index register B 
If B™^ = 2, use index register B^ 

If B^ = 0, no indexing 
Bits'^2-14 of the index register are 
used for word address indexing (13-bit 
index-sign extended). Bits 00 and 01 
must be set to "I's". 

s = unmodified address of the highest order 
character in BCD field C. S = [s + Bs3 
Bg = index register flag for field C. 

(same bit functions as B^^) 

^2 ~ number of characters in BCD field C 
DC = 8-bit delimiting character compared 
against characters in field A 

Bits 20 through 23 at P + 2 and 00 and 01 at P 
should be loaded with zeros. 

Instruction Description; Convert a field of up to 4095 8-bit American Standard 
Code for Information Interchange (ASCII) characters in field A into 6-bit BCD 
characters in field A. Conversion proceeds from left to right. The operation 
is terminated when $2 is exhausted or an ASCII character equal to the delimiting 
character is recognized. A character equal to the delimiting character is con¬ 
verted when encountered. 

Comments: A BCD fault is generated if bit positions 05 and 06 for any character 
contain both "I's" or both "O's" (an illegal character). An illegal character is 
set to zero in field C and conversion continues to completion. The B^ register 
indicates the number of BCD characters stored. 

The first ASCII character is always derived from this character position of the 
word specified by M. Shaded areas are not used, i 


M 

M + 1 


23 20 19 


'12 II 08 07 


00 




FIRST ASCII 
CHARACTER 



SECOND ASCII 
CHARACTER 

23 

20 19 

12 

11 

08 

07 00 


THIRD ASCII 
CHARACTER 



FOURTH ASCII 
CHARACTER 
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p 


p + 1 


P + 2 


Br = index register flag for field A ^ 

If Bj, = 1 or 3, use index register B 
If Bj, = 2, use index register B^ 

If B^ = 0, no indexing 
m = unmodified address of the lowest or¬ 
der word in field C... 

M = m + [ Bj^] 

B = index register flag for field C 
(same bit functions as 
Bits 02-14 of the index register are 
used for word address indexing (13-bit 
index-sign extended). Bits 00 and 01 
must be set to " 1's”. 

S 2 = number of 6-bit characters in field A, 
to pack. 

Bits 00 and 01 or P + 1, and bits 12 through 23 of 
P + 2 should be loaded with zeros. 

Instruction Description: Convert from right to left, a field of numeric 6-bit BCD 
characters in field A into 4-bit BCD characters and store the result in field C. 

The upper 2 bits of all 6-bit characters are removed. 

Comments: The sign of field A is contained in the upper 2 bits of the lowest order 
character. This sign is converted into a 4-bit sign character (IOIO 2 - positive, 

101 12 - negative) and is placed in the low order character position of field C prior 
to packing BCD characters. Any A field character with a 12o - 170 code is forced 
to a zero in field C. A full word store is used. Any unfillea 4-bit characters in 
the highest order word are stored as zeros. The B^ register contains a count 
equal to four times the number of store cycles. The BDP Condition register is 
not used. 

A BCD fault is generated if one of the following conditions occur: 

1. Zone portion (upper 2 bits) of any character (except sign character) does 
not equal zero. 

2. Numeric portion (lower 4 bits) of any character in field A contains a BCD 
code greater than llg, except the sign character where a 12g code is legal. 

3. The lowest order character (sign character) is field A contains a 72g code. 

Operation continues despite any BCD fault. 


23 18 17 16 00 



r = unmodified address of the lowest or¬ 
der character in the A field. 

R = r + [ B^] 


PAK 

Convert 6-Bit 
BCD to 4-Bit BCD 
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18 17 16 


02 0100 


P 


P + 1 


P + 2 


m = unmodified address of the lowest or¬ 
der word in field A. 

M = m + [ Bp] 

= index register flag for field A ^ 

If B = 1 or 3, use index register B”^ 

If B^ = 2, use index register B^ 

If b”^ = 0, no indexing 
Bits^2-14 of the index register are used 
for word address indexing (13-bit index- 
sign extended). 

Bits 00 and 01 must be set to "I's". 
s = immodified address of the lowest order 
character in field C. S = [^s + Bs^] 

B = index register flag for field C 
(same bit functions as B ) 

So = number of characters resulting in 
field C. 

Bits 00 and 01 of P and bits 12 through 23 should be 
loaded with zeros. 

Instruction Description: Convert a field of numeric 4-bit BCD characters in field 
A into 6-bit BCD characters and store the result in field C. The upper 2 bits of 
the new 6-bit characters are all set to "00" except the lowest order character 
which receives the algebraic sign from the 4-bit sign character (lowest order) in 
field A. Field C contains one less character than field A due to the elimination 
of the 4-bit sign character. 

Comments: The conversion proceeds from right to left commencing with the sign 
character of the 4-bit BCD field. If the sign is positive (lOlOg), a "00" is stored 
in the upper 2 bits of lowest order 6-bit BCD character; if negative (lOll^), a "10" 
is stored in the upper 2 bits of this character. Any A field character (other than 
the sign character) containing a 12g - 17g code results in a zero in field C. 

3 

The B register indicates the munber of 6-bit characters stored. The BDP Con¬ 
dition register is not used. 

A BCD fault is generated if one of the following conditions occur; 

1. The sign character in field A is other than IOIO 2 or IOII 2 (the sign of 
field C is then set to zero), or 

2. Any other character in field A contains a 12g - 17p code, except the 
second lowest character where a 12g code is legal; 



UPAK 

Convert 4-Bit 
BCD to 6-Bit BCD 


Operation continues despite any BCD fault. 
Rev. C 5-122 





Character Search Instructions 


— 

Operation Field 

Address Field 

Interpretation 

SRCE,INT 

71 SC, r, s 

Search for character equality 

SRCN.INT 

71 SC, r, s 

Search for character inequality 

SCAN, LR, EQ 

65 r, Bj,,S 2 , SC 

Scan field (left to right) for equal 
condition 

SCAN, LR, EQ, DC 

65 r, Bj,, S 2 , SC 

Scan field (left to right) for equal 
condition with delimiting 

SCAN, LR, NE 

65 r, S 2 ,SC 

Scan field (left to right) for not 
equal condition 

SCAN,LR, NE, DC 

65 r, Bj,, ^ 2 , SC 

Scan field (left to right) for not 
equal condition with delimiting 

SCAN, RL, EQ 

65 r, B^, S 2 , SC 

Scan field (right to left) for equal 
condition 

SCAN,RL, EQ, DC 

65 r, Bj,, S 2 , SC 

Scan field (right to left) for equal 
condition with delimiting 

SCAN, RL, NE, DC 

65 r, Bj., § 2 , SC 

Scan field (right to left) for not 
equal condition 

SCAN,RL, NE, DC 

65 r, Br, ^ 2 , SC 

Scan field (right to left) for not 
equal condition with delimiting 
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SRCE 
Search for 
Character Equality 


P 

P + 1 


23 18 17 16 _00 


71 

1 

N 

T 

s 

23 18 17 16 00 

SC 

0 

r 


INT = "I” for interrupt upon completion 
s = last character address of the 
search block, plus one 
SC = 6-bit BCD scan character 

r = first (current) character address 
of the search block 


Instruction Description: This instruction initiates a search through a block of 
character addresses in storage looking for equality with the scan character, SC. 

If Search/Move control is not busy, the buffered search operation commences 
while Main Control performs an RNI at P + 3. Main Control continues executing 
the main program while the search operation occurs simultaneously. If Search/ 
Move control is initially busy. Main Control performs an RNI at P + 2 and the 
search operation does not occur. 

As a search progresses, r is incremented until the search terminates when 
either a comparison occurs between the scan character 'SC and a character in the 
storage field, or until r=s. If a comparison does occur, the address of the satisfy¬ 
ing character may be determined by inspecting r. To do this, transfer the con¬ 
tents of register 20 to A with instruction TMA (53 0 2002 0). 

Register 20 of the register file is reserved for the second instruction word 
which contains the current character address of the search block. Register 30 
is reserved for the first instruction word which contains the last character ad¬ 
dress of the search block, plus one. 

Figure 5-15 is a flow chart of steps that occur during a search operation. 
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-15. SRCE Operation 



Search Control 
Generates Block" 
Control Request 


Read Up 
Register 20 
(P + 1) 


P'irslCliai-acter I 
To Be Inspeotecy 


Jlncrcment 
1r by 1 


He sto re 
Register 20 


Read Up 
Register 30 
(P) 


Restore 
Register 30 
(P) 


No Increment 
Por First 
Character 


Request 

MCS 


Transfer 
(S2) lo S 
lius 


JXransfer r to 
Register 


Load Search 
Character SC 
into DBR 



_1 



INT = 1 


1 

Release R. F. 

i - 



and Terminate 

ocrti «. h 





i 






























SRCN 


Search for 

P 

Character Inequaiity 


P+1 


23 


18 17 

16 


00 

7i 


S 

23 


18 17 16 


00 

SC 

0 

r 


INT = "1" for interrupt upon completion 
s = last character address of the 
search block, plus one 
SC = 6-bit BCD scan character 
r = first (current) character address 
of the search block 

Instruction Description : This instruction initiates a search through a block of 
character addresses in storage looking for inequality with scan character SC. 

If Search/Move control is not busy, the buffered search operation occurs 
simultaneously. If Search/Move control is initially busy. Main Control performs 
an RNI at P + 2 and the search operation does not occur. 

As a search progresses, r is incremented until the search terminates when 
either an unequal character comparison occurs between the search character SC 
and a character in storage, or until r = s. If an unequal character comparison 
does occur, the address of the satisfying character may be determined by in¬ 
specting r. To do this, transfer the contents of register 20 to A with instruc¬ 
tion TMA (53 0 20020). 

Register 20 of the register file is reserved for the second instruction word 
which contains the current character address of the search block. Register 30 
is reserved for the first instruction word which contains the last character ad¬ 
dress, plus one of the search block. 

Figure 5-16 is a flow chart of steps that occur during a search operation. 
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Figure 5-16. SRCN Operation 
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SCAN, LR, EQ 

Search Field A Left 
to Right for Equality 

1 

P 


P + 1 ! 

1 


P + 2 


23 


le 17 16 


00 


65 


23 21 20 19 IB 


00 


Br 






23 


IB 17 


12 II 


r = unmodified address of the highest or¬ 
der character in field A, R = r + [ B]-] 

Bp = index register flag for field A 

If Bp = 1 or 3, use index register B^ 

If Bj, = 2, use index register B^ 

If Bp = 0, no indexing 

SC = 6-bit scan character compared against 
characters in field A 

^2 = number of characters to be searched 

Bits 00 through 18 of P + 1 and bits 12 through 17 
of P + 2 should be loaded with zeros. 

Instruction Description: Search field A from left to right beginning with the 
6-bit character at location R and RNI at P + 4 if a character is found that is 
equal to the scan character, SC. If a character is not found that equals the SC 
after the entire field defined by S 2 has been searched, RNI at P + 3, 

Comments : If a character comparison occurs during the search, the number of 
searched characters is transferred to the lower 12 bits of b 3. If an unsuccessful 
search is made, then (b 3) = Sg- Th® upper 3 bits of B^ are of no consequence 
in this instruction. BCD codes of 12o, 32„, and 52o do not compare equal to 
zero for this instruction. o e » 

The BDP Condition register is not used. 
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23 


18 17 16 


00 


SCAN, LR, EQ. DC 
Search Fieid A Left to 
Right for Equality, Delimited 


65 

R 

r 

23 21 2019 18 00 

0 

Br 


23 18 17 12 II 00 

SC 

DC 

S2 


r = unmodified address of the highest or¬ 
der character in field A. R = r + [ B^.] 

index register flag for field A 
If Bj, = 1 or 3, use index register B^ 

If B^ = 2, use index register B^ 

If Bj. = 0, no indexing 
6-bit scan character compared against 
characters in field A, 
number of characters to be searched. 
6-bit delimiting character compared 
against characters in field A 

Bits 00 through 18 of P + 1 should be loaded with 
zeros. 

Instruction Description: Search field A from left to right beginning with the 
6-bit character at location R and RNI at P + 4 if a character is found that is 
equal to the scan character, SC. If a character is not found that equals the SC 
after the entire field defined by S2 has been searched or if a character is found 
that equals the delimiting character, DC, RNI at P+3. (If SC equals DC and com¬ 
parison with field A occurs, RNI at P + 4). 

Comments: If a character comparison is found during the search, the number 
of characters searched is transferred to the lower 12 bits of B^. If an unsuc¬ 
cessful search is made, then (B^) = upper 3-bits of B^ are of no 

consequence in this instruction, BCD codes of 12g, 32g, and 52g do not compare 
equal to zero for this instruction. 

The BDP Condition register is not used. 


Br = 

SC = 

S2 = 
DC = 
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SCAN, LR, NE 

23 le 17 16 


00 

Search Field A Left p I 

65 

0 

r 

to Right for Inequality 

23 21 20 19 18 




00 


p + 1 


Br 






23 


IS 17 


12 II 


00 


P + 2 


sc 


r = unmodified address of the highest or¬ 
der character in field A. R = r + [ B^] 

Bp = index register flag for field A 

If Bj. = 1 or 3, use index register B^ 

If B^ = 2, use index register B^ 

If Bj, = 0, no indexing 

SC = scan character which is compared 
against characters in field A. 

S 2 = number of characters to be searched 


Bits 00 through 18 of P + 1 and bits 12 through 17 
of p+ 2 should be loaded with zeros. 


Instruction Description: Search field A from left to right beginning with the 6 - 
bit character at location R, and RNI at P + 4 if a character is found that is not 
equal to the scan character , SC. If a character is not found that is not equal 
to the SC after the entire field defined by ^2 has been searched, RNI at P + 3. 


Comments: If an unequal character comparison is found during the search, the 
number of characters searched is transferred to the lower 12 bits of B'^. If all 
characters searched are equal to the SC, then (B^) -^2‘ upper 3 bits of B^ 

are of no consequence in this instruction. BCD codes of 120 , 323 , and 523 do not 
compare equal to zero for this instruction. 

The BDP Condition register is not used. 
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SCAN, LR. NE, DC 


Search Field A Left to 

P 

Right for Inequality, Delimited 



P + 1 


P + 2 



r = unmodified address of the highest or¬ 
der character in field A. R = r + [ Bj,] 

Bp = index register flag for field A 

If Br = 1 or 3, use index register B^ 

If Bj;. = 2, use index register B^ 

If Bj- = 0, no indexing 
SC = scan character which is compared 
against characters in field A. 

S 2 = number of characters to be searched 
DC = 6-bit delimiting character compared 
against the characters in field A 


Bits 00 through 18 of p + 1 should be loaded with 
zeros. 


Instruction Description: Search field A from left to right beginning with the 
6 -bit character at location R, and RNI at P + 4 if a character is found that is 
not equal to the scan character, SC. If a character is not found that is not 
equal to the SC after the entire field defined by S 2 has been searched or if a 
character is found that equals the delimiting character, DC, RNI at P + 3. 

(If SC equals DC and an unequal comparison with field A occurs, RNI at P + 4), 

Comments: If an unequal character comparison is found during the search, the 
number of characters searched is transferred to the lower 12 bits of B^. If all 
characters searched are equal to the SC, then (B'^) = ^2 • The upper 3 bits of B^ 
are of no consequence in this instruction. BCD codes of 12g, 32g and 52g cause 
an unequal comparison to zero. 

The BDP Condition register is not used. 
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SCAN, RL, EQ 
Search Field A Right 
to Left for Equality 


P 

P + 1 

P + 2 



r = unmodified address of the lowest or¬ 
der character in field A. R = r + [ B^,] 

Bp = index register flag for field A 

If Bp = 1 or 3, use index register B^ 

If Bp = 2, use index register b 2 
If Bp = 0, no indexing 
SC = scan character which is compared 
against characters to be searched. 

S 2 = number of characters to be searched 

Bits 00 through 18 of p + 1 and bits 12 through 17 
of P + 2 should be loaded with zeros. 

Instruction Description: Search field A from right to left beginning with the 6-bit 
character at location R and RNI at P + 4 if a character is found that is identical to 
the scan character, SC. If a character is not found that equals the SC after the 
entire field defined by S 2 been searched, RNI at P + 3. 

Comments: If a character comparison is found during the search, the number of 
characters searched is transferred to the lower 12 bits of B'^. If an imsuccessful 
search is made, then (B^) = Sn. The upper 3 bits of are of no consequence in 
this instruction. BCD codes of 12g, 32g, and 52g do not compare equal to zero. 

The BDP Condition register is set ot the sign of field A (upper 2 bits of lowest 
order character). 
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SCAN, RL, EO. DC 
Search Field A Right P 

to Left for Equality, Delimited 

P + 1 


P + 2 


23 


18 

17 16 

00 

65 

0 

r 

23 21 2019 18 



00 

rn 

Br 


23 


18 17 

12 

II 00 

SC 

DC 



r = unmodified address of the lowest or¬ 
der character in field A. R = r + [ B^] 

index register flag for field A 
If Br = 1 or 3, use index register B^ 

If Br = 2, use index register B^ 

If Br = 0, no indexing 
scan character which is compared 
against characters in field A. 
number of characters to be searched 
6 -bit delimiting character compared 
against the characters in field A 

Bits 00 through 18 of p + 1 should be loaded with 
zeros. 

Instruction Description: Search field A from right to left beginning with the 6- 
bit character at locations R and RNI at P + 4 if a character is found that is 
equal to the scan character, SC. If a character is not found that equals the SC 
after the entire field defined by ^2 been searched or if a character is found 
that equals the delimiting character ^ DC, RNI at P + 3 (if SC equals DC and an 
equal comparison with field A occurs, RNI at P + 4). 

Comments: If a character comparison is found during the search, the number of 
characters searched is transferred to the lower 12 bits of B^. If an unsuccessful 
search is made, then (B^) = S 2 - The upper 3 bits of B^ are of no consequence in 
this instruction. BCD codes of 12g, 32g, and 52g do not compare equal to zero. 

The BDP Condition register is set to the sign of field A (upper 2 bits of lowest 
order character). 
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23 


18 17 16 


00 


SCAN, RL, NE 


Search Field'A Right 

P 

to Left for Inequality 



P + 1 


P + 2 



r = unmodified address of the lowest or¬ 
der character in field A. R = r + [ B^] 

Br = index register flag for field A 

If Br = 1 or 3, use index register B^ 

If Br = 2, use index register B^ 

If Br = 0, no indexing 
SC = scan character which is compared 
against characters in field A 
$2 = number of characters to be searched 

Bits 00 through 18 of P + 1 and bits 12 through 17 
of P + 2 should be loaded with zeros. 

Instruction Description: Search field A from right to left beginning with the 6- 
bit character at location R and RNI at P + 4 if a character is found that is not 
equal to the scan character, SC, If a character is not found that is not equal 
to the SC after the entire field defined by §2 has been searched, RNI at P + 3. 

Comments: H an unequal character comparison is found during the search, the 
number of characters searched is transferred to the lower 12 bits of B 3, E all 
characters searched are equal to the SC, then (B^) = S o’ upper 3 bits of B^ 

are of no consequence in this instruction. BCD codes 12g, 32g, and 52g cause an 
unequal comparison to zero. 

The BDP Condition register is set to the sign of field A (upper 2 bits of lowest 
order character). 
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SCAN, RL, NE, DC 
Search Field A Right P 

to Left for Inequality, Delimited 

P + 1 

P + 2 



r = unmodified address of the lowest or¬ 
der character in field A. R = r + [ Bj,] 

Bj. = index register flag for field A 

If Bj, = 1 or 3, use index register B^ 

If Bj- = 2, use index register B^ 

If Bj. = 0, no indexing 
SC = scan character which is compared 
against characters in field A 
^2 = number of characters to be searched 
DC = 6-bit delimiting character compared 
against the characters in field A 

Bits 00 through 18 of P + 1 should be loaded with 
zeros. 

Instruction Description; Search field A from right to left beginning with the 6- 
bit character at location R and RNI at P + 4 if a character is found that is not 
equal to the scan character, SC. If a character is not found that is not equal 
to the SC after the entire field defined by S 2 has been searched, or if a charac¬ 
ter is found that equals the delimiting character, DC, RNI at P + 3 (If SC equals 
DC and an unequal comparison with field A occurs, RNI at P + 4). 

Comments: If an unequal character comparison is found during the search, the 
number of characters searched is transferred to the lower 12 bits of B^. If all 
characters searched are equal to the SC, then (B^) = S 2- upper 3 bits of B^ 

are of no consequence in this instruction. BCD codes of 12g, 32g, and 52g cause 
an unequal comparison to zero. 

The BCD Condition register is set to the sign of field A (upper 2 bits of lowest 
order character). 
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Move Instructions 


Operation Field 

Address Field 

Interpretation 

MOVE,INT 

72 

S, r, s 


Move characters from r to s. 

MVE 

64 

r, Br, Si, s, Bg, 

S 2 

Move field 

MVE, DC 

64 

r, Bp, s, Bg, S2 


Move field with delimiting 

MVBF 

64 

r, B 2 ;., Si, s, Bg, 

^2 

Move field and blank fill 

MVZF 

64 

r, B^, Si,s, Bg, 

^2 

Move field and zero fill 

MVZS 

64 

^> Bj., Sjj^, s, Bg, 

^2 

Move field and suppress zeros 

MVZS, DC 

64 

r i B^, s, Bg, §2 


Move field and suppress zeros with 
delimiting 

ZADM 

67 

r, Br, Si, s,Bg, 

^2 

Move field and add zeros 

FRMT 

64 


^2 

Move field and format with commas 
and decimal point 

EDIT 

64 

Bj^, Si, s, Bg, 

S 2 

Move field and perform complete 
COBOL edit 
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23 


18 17 16 


00 


MOVE p 

Move S 

Characters from r to s 

P + 1 


72 

0 

S 

23 

17 

16 


00 

S 

r 


INT = "l" for interrupt upon completion 
s = first address of character block 
destination 

S = field length of data block, 0-177g=!= 
characters 

r = first address of character block 
source 

Instruction Description : This instruction moves a block of characters from one 
area of storage to another. If Search/Move control is not busy, the buffered move 
operation commences while Main Control performs an RNI at P + 3. Main 
Control continues executing the main program while the move operation occurs 
simultaneously. If Search/Move control is initially busy. Main Control performs 
an RNI at P + 2 and the move operation does not occur. 

As a move operation progresses, r and s are incremented and S (number of 
characters) is decremented until S = 0. 128 characters or 32 words may be 

moved. When bits 00 and 01 of r and s are zero, and the field length is a multiple 
of four characters, data is moved word by word. This reduces the move time by 
75% over a character by character move. 

Register 21 of the Register File is reserved for the second instruction word 
which contains the first address of the character block source. Register 31 is 
reserved for the first instruction word which contains the first address of the 
character block destination. 

Figure 5-17 is a flow chart of steps that occur during a move operation. 


* = 1-1778 represents a field length of 1 to 127 characters; 0 represents a field 
length of 128 characters. 
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P + 1 


P + 2 



r = unmodified address of the highest or¬ 
der character in field A. R = r + [ Bp] 

Bj, = index register flag for field A 

If Bp = 1 or 3, use index register B^ 

If Bp = 2, use index register B^ 

If Bp = 0, no indexing 
s = unmodified address of the highest or¬ 
der character in field C, S = s + [ Bg] 

Bg = index register flag for field C (same 
bit functions as Bp) 

S 1 = number of characters in field A to be 
moved 

^2 ~ number of available character posi¬ 
tions in field C 

Instruction Description : Move a field of up to 4095 6-bit alphanumeric characters 
from field A to field C, left to right. 

Comments: If field A is longer than field C, the length of field C, %2> termi¬ 
nates the move operation and the remainder of the A field is not moved. If 
field C is longer than field A, the length of field A terminates the move opera¬ 
tion and the remainder of the C field remains unchanged. 

The BDP Condition register is set to the sign of field A if the sign character 
(lowest order character) is moved. It is set to OO 2 for a positive sign (or no sign 
transferred) and to 10g for a negative sign. 
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V'-r.'.'-.'V-'M,-.- i'A • 
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p + 1 


P + 2 


00 


64 

0 

r 

23 21 

2019 18 17 16 

00 

1 ° 

bJ 

5 

S 

s 

23 


18 17 

12 

11 00 



I 

DC 

S 2 


r = unmodified address of the highest or¬ 
der character in field A. R = r + [ 

By = index register flag for field A 

If Bp = 1 or 3, use index register B^ 

If Bp = 2, use index register B2 
If Br = 0, no indexing 
s = unmodified address of the highest or¬ 
der character in field C. S = s + [Bg] 

Bg = index register flag for field C (same 
bit functions as Bf) 

S 2 = number of available character posi¬ 
tions in both field A and field C 

DC = 6-bit delimiting character compared 
against the characters in field A 

Bits 18 through 23 of P + 2 should be loaded with 
zeros. 

Instruction Description: Move a field of up to 4095 6-bit alphanumeric charac¬ 
ters from field A to field C, left to right. 

Comments: The length of field C, § 2 . terminates the move operation. If the 
delimiting character is recognized at any time during the character move, the 
operation is terminated after the delimit character has been moved. 

The BDP Condition register is set to the sign of field A if the sign character 
(lowest order character) is moved. It is set to 002 for a positive sign (or no 
sign transferred) and to IO 2 for a negative sign. 
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MVBF 


Move Field A to 

p 

Field C and Blank Fill 



p +1 


P + 2 


23 



18 

17 

16 


00 

64 

y 

r 

23 

21 

2019 

18 

17 

16 


00 

1 

Br 

ll 


s 

23 






12 II 

00 


S, S2 


r = unmodified address of the highest or¬ 
der character in field A. R = r + [ Bj.] 

Bj. = index register flag for field A 

If Bj- = 1 or 3, use index register b 1 
If B]- = 2, use index register b 2 
If Bj;. = 0, no indexing 
s = unmodified address of the highest or¬ 
der character in field C. S = s + [Bg] 

Bg = index register flag for field C (same 
bit functions as Bj-) 

S 1 = number of characters in field A to be 
moved 

S 2 = number of available character posi¬ 
tions in field C 

Instruction Description : Move a field of up to 4095 6-bit alphanumeric charac¬ 
ters from field A to field C, left to right. 

Comments: If field A is longer than field C, the length of field C, S2> termi¬ 
nates the move operation and the remainder of field A is not moved. If 
field C is longer than field A, the remainder of field C is filled with blanks. 

The BDP Condition register is set to the sign of field A if the sign character 
(lowest order character) is moved. It is set to OO 2 for a positive sign (or no 
sign transferred) and to IO 2 for a negative sign. 
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23 


le 17 16 


00 


MVZF 

Move Field A fo Field 
C and Zero Fill 


P 

P + 1 

P + 2 


64 


r 

23 212019 18 17 16 

00 

1 " 

illJ 

Bs 

s 

23 




12 

11 00 

Si 

S 2 


r = unmodified address of the highest or¬ 
der character in field A. R = r + [ Bj^] 

Bj;. = index register flag for field A 

If B]- = 1 or 3, use index register B^ 

If B]- = 2, use index register b 2 
If Br = 0, no indexing 
s = unmodified address of the highest or¬ 
der character in field C, S = s +[Bs] 

Bg = index register flag for field C (same 
bit functions as B^^) 

S j = number of characters in field A to be 
moved 

S 2 = number of available character posi¬ 
tions in field C 

Instruction Description: Move a field of up to 4095 6-bit BCD numeric charac¬ 
ters from field A to field C, left to right. 

Comments: If field A is longer than field C, the length of field C, S2, terminates 
the move operation and the remainder of field A is not moved. If field C is lon¬ 
ger than field A, the remainder of field C is filled with zeros. The upper 2 bits 
of all field A characters are stripped (forced to zero) when moved to field C. 

Any field A character containing a 12g - 17g code is forced to zero when moved. 

The sign from field A (upper 2 bits of lowest order character) is always trans¬ 
ferred to the BDP Condition register and to the lowest order character in field C 
(this may be a zero-filled character), even if the A field is longer than the C field. 
A BCD fault is generated if one of the following conditions occur: 

1. Zone portion (upper 2 bits) of any character in field A (except sign charac¬ 
ter) does not equal zero. 

2. Numeric portion (lower 4 bits) of any character in field A contains a BCD 
code greater than llg, except the sign character where a 12g code is 
legal. 

3. The lowest order character (sign character) contains a 72g code. 

Operation continues despite any BCD fault. 
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MVZS 

Move Field A to Field 
C and Zero Suppress | 


23 18 17 16 00 



r = unmodified address of the highest or¬ 
der character in field A. R = r + [ Bj.] 

Br = inaex register flag for field A 

If Br = 1 or 3, use index register B^ 

If Bj, = 2, use index register B^ 

If Bj. = 0, no indexing 
s = unmodified address of the highest or¬ 
der character in field C. S - s + [ B„] 

Bg = index register flag for field C (same 
bit functions as Bp) 

5 1 = number of characters in field A to be 

moved 

5 2 = number of available character posi¬ 

tion in field C 

Instruction Description; Move a field of up to 4095 6-bit alphanumeric characters 
in field A to field C, left to right, and replace all leading zeros occurring in field 
A with blanks in field C. 

Comments : If field A is longer than field C, the length of field C, S 2 ^ termi¬ 
nates the move operation and the remainder of the A field is not moved. In 
this case, the sign bits may be invalid (Sign bits are not checked or modified and 
consist of the upper two bits of the last character moved,) 

If field C is longer than field A, the length of field A terminates the move oper¬ 
ation and the remainder of field C remains unchanged. 

The BDP Condition register is set according to the sign of the A field if the sign 
character is processed. 
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23 


18 17 16 


00 


MVZS, DC 


Move Field A to Field 

P 

C and Zero Suppress, Delimited 



P + 1 


P + 2 


64 

■ 

r 

23 2120 19 181718 

00 


Br 

Bs 

s 

23 

1 

8 17 

12II 00 


DC 

S2 


r = unmodified address of the highest or¬ 
der character in field A, R = r + [ Bp] 

Bp = index register flag for field A 

If Bp = 1 or 3, use index register B^ 

If Bp = 2, use index register B^ 

If Bp = 0, no indexing 
s = unmodified address of the highest or¬ 
der character in field C. S = s + [ Bs] 

Bg = index register flag for field C (same 
bit functions as Bp) 

S 2 = number of available character posi¬ 
tions in both field A and field C 

DC = 6-bit delimiting character compared 
against the characters in field A 

Bits 18 through 23 of P + 2 should be loaded with 
zeros. 

Instruction Description: Move a field of up to 4095 6-bit alphanumeric characters 
from field A to field C, left to right, and replace all leading zeros occurring in 
field A with blanks in field C. 

Comments : The length of field C, $ 2 ’ terminates the move operation. If the 
delimiting character is recognized at any time during the character move, the 
operation is terminated after the delimit character has been moved. The sign of 
the newly formed C field may be invalid (Sign bits are not checked or modified 
and consist of the upper 2 bits of the last character moved.) 

The BDP Condition register is always set to a positive sign (OO 2 ). 
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23 


18 17 16 


00 


ZADM 

Zero 

and Add Move 


P 

P + 1 

P + 2 


67 0 

r 

23 2120 1918 17 16 00 

2 Br Bs 

s 

23 

12 II 00 

Si Sa 


r = unmodified address of the lowest or¬ 
der character in field A. R = r + [ Bj,] 

Bp = index register flag for field A 

If Br = 1 or 3, use index register B^ 

If Bj- = 2 , use index register B2 
If B]- = 0, no indexing 
s = unmodified address of the lowest or¬ 
der character in field C. S = s + [ Bg] 

Bg = index register flag for field C (same 
bit functions as Bj-) 

S = number of characters in field A to 
be moved 

^2 = number of available character posi¬ 
tions in field C 

Instruction Description : Move a field of up to 4095 6-bit BCD numeric charac¬ 
ters from field A to field C, right to left. 

Comments: If field A is longer than field C.. the length of field C, %2> termi¬ 
nates the move operation and the remainder of the A field is not moved. If 
field C is longer than field A, the remainder of field C is filled with zeros. 

The algebraic sign of field A is obtained from the upper 2 bits of the lowest order 
character in field A. A lOg indicates a negative field and OO 2 , OI 2 , or II 2 indi¬ 
cates a positive field. This sign is stored in the upper 2 bits of the lowest order 
character in field C, The BDP Condition register is also set to the sign of field C. 

Any field A character with a 12g - 17g code if forced to zero when moved, 

A BCD fault is generated if one of the following conditions occur; 

1. Zone portion (upper 2 bits) of any character in field A (except sign charac¬ 
ter) does not equal zero. 

2. Numeric portion (lower 4 bits) of any character in field A contains a BCD 
code greater than Hg; except the sign character where a 12g code is legal, 

3. The lowest order character (sign character) contains 0.12^ code. 

Operation continues despite any BCD fault. 
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23 


18 17 16 


00 
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Move Field A 


P 

and Format in Field C 





P + 1 



P + 2 


23 21 20 19 18 17 16 


00 


n 

Br 

CD 

(/> 

S 

23 



12 II 


00 


Sr 


r = unmodified address of the highest or¬ 
der character in field A. R = r + [ B^] 

Br = index register flag for field A 

If Br = 1 or 3, use index register 
If Br = 2, use index register B^ 

If Br = 0, no indexing, 
s = unmodified address of the highest or¬ 
der character in field C, S = s + [Bg] 

Bg = index register flag for field C (same 
bit functions as Bj,) 

S j = number of characters in field A to be 
edited, (Values must be 2 , 5, lOg, 

ISg, ISg, etc,) 

S 2 = number of characters in field C, 

Values of S 2 must be 3, 6 , 123 , 

163 , 223 , etc, and include decimal point 
and commas). 

Instruction Description: Move the numeric characters in field A from left to 
right into field C, replacing leading zeros with blanks and inserting a comma 
after every three characters moved. A decimal point is inserted in the third 
lowest order position of the C field. 

Comments: Leading zeros in field A, together with normally inserted commas, 
are suppressed until the first non-zero character is encountered. Zero sup¬ 
pression terminates with the decimal point if only zeros are encountered. 

The sign of field A is recorded in the BDP Condition register but does not appear 
in the resultant C field. 

A BCD fault is generated if one of the following conditions occur: 

1. Zone portion (upper 2 bits) of any character infield A (except sign charac¬ 
ter) does not equal zero. 

2. Numeric portion (lower 4 bits) of any character in field A contains a BCD 
code greater than II 3 except the sign character, where a I 23 code is 
legal. 

3. The lowest order character (sign character) contains a 723 code. 

4. Incorrect field length specified - a) the two fields are not aligned (Ex: 

= 2 and §2 ” b) illegal count used (Ex: §2 3, 6 , 12g, 22g, etc,). 

Operation continues despite any BCD fault. 
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EXAMPLE; 




This character address is specified by 'R' 
Field A= 00007689 32 


Si specifies I 33 
characters in 
field A 


This character address 
is specified b 's' I 


Field C = 


® ® ® (s) 


§2 specifies I 63 
I characters (includ- 

I ing decimal point 

and commas) in 
i field C. The count 

I progresses as 

follows: 

I 

7, 6 8 9 . 3 2 
® ® ®® ® ® ® ® ® ® - 


The leading zeros are 
removed, leaving six 
blanks in field C. 
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18 17 16 
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EDIT 
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and Edit in Field C 
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P + 2 


64 

1 

r 

23 21 20 19 18 17 

16 00 

4 

Br 

Bs 

s 

23 12 11 00 

s, 

S 2 


r = unmodified address of the highest or¬ 
der character in field A. R = r + [ Bj.] 

Bj, = index register flag for field A 

If Br = 1 or 3, use index register B^ 

If Br = 2, use index register B^ 

If Bj, = 0, no indexing 
s = unmodified address of the highest or¬ 
der character in field C. S = s + [ Bg] 

Bg = index register flag for field C (same 
bit functions as Bp) 

= number of characters in field A to be 
edited 

S 2 = number of characters in field C 

Instruction Description: Perform a complete formatted edit from left to right 
with up to 4095 characters in field C. The editing is performed character for 
character with respect to the COBOL type editing characters in field C. The 
resulting edited field is stored in field C. 

Comments: Programming consideration must be given to aligning the charac¬ 
ters in field A with the proper editing characters in field C, The COBOL type 
editing characters used in field C and applicable to this instruction are listed 
here with their descriptions. Any other character in the C field is recognized 
as a 9. 

The BDP Condition register is set to the sign of field A. The conditions for a 
BCD fault are the same as for PRMT, with the exception of condition 4, 

Editing examples are listed following the character descriptions; 

EDITING CHARACTERS 
9 $ + - . , 0 B CR DB Z * / 

• Direct Characters; 

9 When the character 9 appears in the C field, it is replaced 
by the corresponding character in the A field. 
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• Insertion Characters: 

When an insertion character is specified in the C field, it remains in 

that character position in the edited field. The insertion characters 

are: 

$ + - . , 0 B CR DB / 

$ When a single dollar sign is specified as the left-most symbol in 
a C field, it appears as the left-most character in the edited field. 
This character is included in the character count ( 82 ) 0 ! the 
edited field. 

+ When a plus sign is specified as the first or last symbol of a C 
field, a plus sign is inserted in the indicated character position 
of the edited data, provided the field of data is positive or is 
unsigned. If the data is negative, a minus is inserted in the in¬ 
dicated character position. The sign is included in the character 
count ( S 2 ) of the edited field. 

When a minus sign is specified as the first or last symbol of a 
C field, a minus sign is inserted in the indicated character posi¬ 
tion of the edited data, provided the field of data is negative. If 
the data is not negative, a blank is inserted in the indicated char¬ 
acter position. The sign or blank is included in the character 
count ( S 2 ) of the edited field. 

(decimal point) This character is used in a C field to represent 
an actual decimal point as opposed to an assumed decimal point. 
When used, a decimal point appears in the edited data as a char¬ 
acter in the same character position as it appears in the C field 
and it is included in the character count of the edited field. A 
picture of a report item can never contain more than one decimal 
point, actual or assumed. 

, When a comma is used in a C field, a comma is inserted in the 
corresponding character position of the edited data. It is in¬ 
cluded in the character count ( S 2 ) of the edited field. 

0 (zero) When a zero is used in a C field, a zero is inserted in the 
corresponding character position in the edited field. It is in¬ 
cluded in the character count ( 83 ) of the edited field. 

B When the character, B, is used in a C field, a blank is inserted 
in the corresponding character position in the edited field. It is 
included in the character count (§ 2 ) of the edited field. 

CR The combined characters (CR) represent a credit in accounting 

operations and may be specified only at the right end of a C field. 
The symbol is inserted in the last two character positions of the 
edited field, provided the value of the data is negative. If the data 
is positive or unsigned these last two character positions are set 
to blanks. Since this symbol always results in two characters 
(CR or blanks) it is included as two characters in the character 
count (S 2 ) of the edited field. 
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DB The combined characters (DB) represent a debit and may be 
specified only at the right end of a C field. It has the same 
results as the credit symbol, using DB or blanks. 

/ (slash) When a slash (/) is used in a C field, a slash is inserted 
in the corresponding character position in the edited field. It is 
included in the character count ( S 2 ) of the edited field, 

• Replacement Characters: 

A replacement character in a C field suppresses leading zeros in data 
and replaces them with other characters in the edited data. The re¬ 
placement characters are: 

Z * $ + - 

Only one replacement character may be used in a picture, although a 
Z or asterisk (*) may be used with any of the insertion characters 
including: 

$ + - 

Z One Z character is specified at the left end of a C field for each 

leading zero in the A field that requires suppression and replace¬ 
ment by a blank in the edited field. Z's may be preceded by one 
of the three insertion characters $ + or - and interspersed with 

the four insertion characters , , 0 or B. Whether these insertion 
characters affect the result of the editing process depends on the 
nature of the data. 

Suppressing leading zeros and inserting blanks ceases when one of the 
following conditions exists: 

1. When the number of suppressed zeros equals the number of Z's 
specified in the C field, 

2. When the first non-zero digit character in the A field is 
encountered. 

3. When the position in the C field is reached where a decimal point 
insertion is specified. Zero suppression and blank replacement 
cannot continue beyond a decimal point, hence, a decimal point 
is never followed by blanks in an edited field, 

• If either a $ + - is specified before Z's, the character 
is inserted in the edited data regardless of leading zero 
suppression. 

0 If either a comma, B, or 0 is encountered in the edit 

field before zero suppression has terminated, the charac¬ 
ter is not inserted in the edited data, but is suppressed 
and a blank is inserted. 

• In the special case where the edited data has a value of 
zero, the entire edited data is replaced by blanks if a 9 
does not appear in the edit picture. This special rule 
overrides the condition that zero suppression terminates 
when a decimal point is encountered. If one of the three 
insertion characters $ + - is specified but the value of 
the edited field is zero, a blank is inserted instead of the 
insertion character. 
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* The asterisk (*) is specified in the same way and with the same 
results as the character Z, except that suppressed characters 
are replaced by asterisks instead of blanks. The rules for the 
Z character apply also to the use of the asterisk. 

$ If one more dollar sign ($) than the number of leading zeros to 

be suppressed is specified at the left end of a C field, this dollar 
sign acts as an insertion character. Each of the other dollar 
signs corresponds to a leading zero to be suppressed. This use 
of the dollar sign has the same results as described for the Z 
character, except that the dollar sign is inserted directly pre¬ 
ceding the first non-suppressed character. A dollar sign used 
in this way as a replacement character is known as a floating 
dollar sign as it virtually "floats" through all of the suppressed 
characters. 

If one or more floating dollar signs are specified in a C field, the 
edited data always contains a dollar sign whether or not any sup¬ 
pression occurs since one of the dollar signs is an insertion char¬ 
acter. Each dollar sign specified in a picture (including the in¬ 
sertion $) is included in determining the character count (S 2 ) of 
the edited field. 

+ When a plus- sign (+) is used as a replacement character, it func¬ 
tions'as a floating plus sign and is specified in the C field one 
more time than the number of leading zeros to be suppressed. 

Its function is the same as the floating dollar sign, with the fol¬ 
lowing exception: 

If the A field data is positive or unsigned a plus 
sign is inserted in the character position directly 
preceding the first non-suppressed character. If 
the A field data is negative,a minus sign is in¬ 
serted in this character position in the edited field. 

When a minus sign is used as a replacement character it functions 
as a floating minus sign and is specified in the C field one more 
time than the number of leading zeros to be suppressed. Its func¬ 
tion is the same as the floating dollar sign and floating plus sign 
with the following exception: 

If theA field data is negative a minus sign is in¬ 
serted in the character position directly preceding 
the first non-suppressed character. If the value of 
theA field data is positive or unsigned, a blank is 
inserted in this position in the edited data instead 
of a minus sign. 
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TABLE 5-10. EDITING EXAMPLES 


Field C 

Field A Data Editing Data 


Resultant Field C 
Edited Data 


UPPFRMOST 

CHARACTER 

-^4 

8 





$99 

$ 

4 

8 





POSITIONS 

4 

8 

3 

4 



$99.99 

$ 

4 

8 

. 

3 

4 



4 

8 

3 

4 



9,999 

4 

J 

8 

3 

4 




2 

9 

2 




+999 

+ 

2 

9 

2 




THE SIGN IS -■" " 

CONTAINED IN 


9 

¥ 




+999 

- 

2 

9 

2 




THE LOWEST ORDER 















CHARACTER, ONLY 
MINUS SIGNS ARE 

2 

9 

2 




999- 

2 

9 

2 

- 



THE A FIGURE 

SHOWN HERE 












, 


■^INDICATES A BLANK 


2 

9 

2 




999- 

2 

9 

2 

A ‘ 



POSITION 


2 

4 

3 

2 

1 


$BB999. 99 

$ 

A 

A 

2 

4 

3 

. 2 1 


2 

4 

3 

2 

1 


$00999. 99 

$ 

0 

0 

2 

4 

3 

. 2 1 


1 

1 

3 

4 



99. 99CR 

1 

1 

• 

3 

4 

C 

R 


1 

1 

3 

4 



99.99CR 

1 

1 

• 

3 

4 

A 

A 


2 

3 

7 

6 



99. 99DB 

2 

3 

• 

7 

6 

D 

B 


2 

3 

7 

6 



99. 99DB 

2 

3 

• 

7 

6 

A 

A 


0 

0 

9 

2 

3 


ZZ999 

A 

A 

9 

2 

3 




0 

0 

9 

2 

3 


ZZZ99 

A 

A 

9 

2 

3 




0 

0 

0 

0 

0 

0 

ZZZZ. ZZ 

A 

A 

A 

A 

A 

A 

A 


0 

0 

9 

2 

3 


$+=:=+. 99 

$ 


•A. 

9 

• 

2 

3 


0 

0 

0 

8 

2 

4 

$$$$9.99 

A 

A 

A 

$ 

8 

• 

2 4 


0 

0 

5 

2 

6 


1 

1 

1 

CD 

CD 

CD 

A 

A 

- 

5 

• 

2 

6 


3 

2 

6 

5 



$$$. 99 

$ 

3 

2 


6 

5 
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Field C Resultant Field C 

Field A Data Editing Data Edited Data _ 

00001234 $ZZZ,ZZZ.99 $AAAAA12. 34 

00123456 99 $=’-* 1,234. 56 

12345634 $>;oi=>K ^ 99 $123,456. 34 

0 0 0 0 1 "2 -ZZZ,ZZZ - A A A A A 1 2 

1 2 3 4 5 6 2 4 $ZZZ, ZZ9.99CR $123,456. 24CR 

00123400 $$$$,$$9.99 AA$1,234.00 

0 0 0 0 0 0 $$$$,$$$.99 AAAAAAAAAAA 

00001256 - ,---.99DB AAAAA-12. 56DB 

1. Only one replacement character of the set Z * $ + and - can be used within 
a single editing C field even though it may be specified more than once. 

2. If one of the replacement characters Z or * is used with one of the 
insertion characters $ + or -, the plus sign or the minus sign may be 
specified as either the leftmost or rightmost character in the editing C 
field, 

3. A plus sign and a minus sign may not be included in the same editing C field. 

4. A leftmost plus sign and a dollar sign may not be included in the same 
editing C field. 

5. A leftmost minus sign and a dollar sign may not be included in the same 
editing C field. 

6 . The character 9 may not be specified to the left of a replacement character. 

7. Symbols which may appear only once are; decimal point, CR, and DB. 

8 . The decimal point may not be the rightmost character in an editing C field. 
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LBR 

Load BCR 


23 


18 17 1514 


00 


70 


m = storage address. Indexing not permitted. 


Instruction Description : Load the BCR and set interrupt recovery conditions 
within the BDP as defined by (m). The 24 bits of (m) have the following signi¬ 
ficance: 


POSITION 
00 and 01 
02 
03 
04 

05 

06 

07 

08 

09 

10 

11 

12 through 23 


FUNCTION 

Contents of the BCR 

Edit flag indicating a "D” (DB) or "C" (CR) character detected. 

Zero suppression operation in progress. 

Edit flag indicating a floating sign ($ + -) operation is in 
progress. 

Edit flag indicating a $ sign is forced. 

Edit flag indicating a + sign is forced. 

Edit flag indicating an * sign is forced. 

Edit flag indicating a floating character is forced. 

Operand equals zero. 

Signs of operands unlike for ADM or SBM, or incorrect on EDIT. 
Interrupt occurred during BDP operation. 

Number of characters or words for Field A already 
processed. 


Comments : The LBR instruction shoxild only be used when returning from an 
interrupt routine. The instruction is trapped if the BDP MODE switch is inactive 
or if the 3312 (BDP) is not present and the computer is operating in non-Executive 
mode or in Program State; it is a No-Op under these conditions in Monitor State. 


S£R 

Store (BCR) 


23 18 17 1514 


00 



m = storage address. Indexing not permitted. 

Instruction Description: Store various operating conditions from within the BDP 
at address 'm'. Refer to the LBR instruction for the bit functions of (m). 

Comments: Execution of this instruction does not clear the operating conditions 
within the BDP. The instruction is trapped if the BDP MODE switch is inactive or 
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if the 3312 (BDP) is not present and the computer is operating in non-Executive 
mode or in Program State; it is a No-Op under these conditions in Monitor State. 
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6. SOFTWARE SYSTEMS 


GENERAL INFORMATION 


Control Data supports its lower 3000 Series Computers with a library of excellent 
standard software products effectively covering a wide range of computer 
applications. 

• Operating Systems exercise supervisory control 

• Languages are oriented toward programming needs 

• Utility routines perform tasks for user's programs 

• Applications systems are specialized programs 

This section briefly describes available software systems and also references 
obtainable documents. To obtain these documents, refer to the Literature 
Distribution Catalog for the correct Publication numbers. 


OPERATING SYSTEMS 


Operating systems provided by Control Data make efficient use of various hard¬ 
ware configurations. These operating systems provide automatic job monitoring 
and supervisory control during compliation, assembly, and execution of user's 
programs. Systems storage requirements are kept at a minimum and operator 
intervention reduced significantly by job stacking, automatic accounting and 
storage allocation, automatic assignment of input/output functions, and by opera¬ 
tor messages produced on the standard output comment unit. Operating systems 
include the following: 

• Real-Time SCOPE 

• MASTER 

• MSOS 

• SCOPE Utility Routines 
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Real-Time SCOPE 

An operating system which provides backgrounding, stacked job processing, and 
priority interrupt handling. Time is shared between a background program and 
the stacked jobs. The standard SCOPE features are included: I/O and status 
operations, debugging facilities, and library maintenance. 

Documents 

General Information 

Real-Time SCOPE Operator’s Manual 

Real-Time SCOPE Reference 


MASTER 

A multiprogramming system that is adaptable to applications involving multi¬ 
access on-line input/output with and without real time calculations as well as to 
conventional and batch processing applications. MASTER uses mass storage for 
system storage and temporary storage of user programs, as well as for storage 
of user files. MASTER allocates tasks to available equipment and handles 
communication among tasks. The tasks are processed on a priority basis. 

Documents 

General Information 
Reference 


MSOS 

Provides utilization of mass storage devices. The operating system, the related 
software packages and library, and user data areas are allocated to disk or 
similar storage. Time is shared between a background program and the stacked 
jobs. Background programs may operate in real time. The system also includes 
priority interrupt handling, I/O and status operations, debugging facilities, and 
library maintenance. 


Documents 

General Information 
MSOS Reference 
MSOS Operator's Manual 
PRELIB MSOS 


SCOPE Utility Routines 

An open-ended peripheral processing package which allows transfer of data 
between peripheral units and storage media. 

Documents 

Reference 
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LANGUAGES 


Programmers can choose the language best suited to the needs of their particular 
problems. Control Data has implemented programming languages which range 
from machine mnemonics to problem-oriented systems which closely resemble 
the natural expressions in particular fields of application. The languages include: 

• FORTRAN 

• COBOL 

• ALGOL 

• COMPASS 

• Data Processing Package 

• Report Generator 


FORTRAN-32 

A versatile mathematical compiler. Most programs written in FORTRAN II and 
FORTRAN IV are compilable with FORTRAN-32. 

Documents 

General Information 
Reference 
Instant FORTRAN 
Library Routines 
Library Functions 


Mass Storage FORTRAN 

Provides all the features of FORTRAN-32 and allows compilation and execution 
using mass storage devices. 


Documents 

General Information 
Reference 

FORTRAN/MASTER 
Instant FORTRAN 
Library Routines 
Library Functions 


COBOL 32 

A data processing language based on the specifications set forth in the DOD 
reference of COBOL-61, Extended. This language provides fast compilation 
speeds and efficient object code. 
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Documents 


General Information 

Reference 

Compatible COBOL 

Version 2.0 Extensions and Revisions 

Instant COBOL 


COBOL 33 

Provides all the features of COBOL 32 and utilizes the Business Data Processing 
hardware during execution of the COBOL object programs. 

Documents 


Reference 


Mass Storage COBOL 

Provides all the features of COBOL 32 and uses mass storage for compilation. 
Version 2 of Mass Storage COBOL contains mass storage statements and allows 
object programs to use mass storage. 

Documents 

General Information 
Reference 

Version 2. 0 Extensions and Revisions 


ALGOL 

A compiler accepting an algorithmic language defined in the ALGOL-60 Revised 
Report in the Communication of the ACM, 1963, Vol, 6, Input/output procedures 
are those of the IFIP set and the complete ACM set. 

Documents 

General Information 
Reference 
Instant ALGOL 

Functional Description ALGOL Compiler 
Abnormal Object Time Termination Dump 


COMPASS-32 

A comprehensive assembly system, providing mnemonic machine operation codes, 
symbolic addressing, assembly-directing pseudo instructions, and programmer- 
defined macro instructions. 
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Documents 


General Information 

Compatible COMPASS Language Reference Manual 
COMPASS/Tape SCOPE COMPASS/Disk SCOPE 
Programming Guide 
Instant COMPASS 

COMPASS/Real-Time SCOPE, COMPASS/MSOS 


COMPASS-33 


An extension of COMPASS-32 designed to process coding for the Control Data 3300. 

Documents 

Compatible COMPASS Language Reference Manual 
Instant COMPASS 

COMPASS/Real-Time SCOPE. COMPASS/MSOS 
COMPASS/MASTER 


Data Processing Package 

Consists of a set of input/output and file description macro instructions. The set 
also includes macros to perform certain data manipulation and mathematical 
functions. 


Documents 

General Information 
Reference 

Report Generator 

Facilitates the preparation of programs which produce a variety of reports from 
an input file. 


Documents 

General Information 
Reference 
Instant Report 


INPUT/OUTPUT 


Input/output control routines are included in the software library to provide access 
to a number of different I/O media through efficiently preprogrammed library 
routines. 
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I/O control programs include: 

• RESPOND/MSOS 

• MSIO 

• SIPP 

RESPOND/MSOS 

A multi-access software package which operates as a background program under 
MSOS and provides users at remote terminals with the ability to access files of 
information contained on mass storage at the central computer site. Files may be 
submitted to the operating system for foreground processing. Records within a file 
may be added, deleted, modified, or displayed by action of the terminal operator. 


MSIO 

A file oriented input/output system consisting of two sections. One section 
provides physical I/O features for mass storage files. The other section provides 
logical record processing facilities such as blocking, deblocking, buffering, 
updating, inserting, and deleting for files on mass storage. 

SIPP 

Enables simultaneous execution of data transfer operations involving several 
peripheral units. If permitted by the operating system, SIPP can operate as a 
background program. 


Reference 


Documents 


APPLICATIONS 


Applications programs are tested working programs which perform specialized jobs 
in industry, business, and research. Applications programs include: 

• PERT/TIME 

• PERT/COST 

• SORT 

• Mass Storage SORT 

• REGINA-1 

• ADAPT 
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PERT/TIME 


Utilizes a time-oriented network structure to provide a variety of reports 
reflecting the actual and scheduled progress of a project. 

Documents 

PERT General Information 
Reference 

Version 2.0 Extensions and Revisions 


PERT/COST 

Utilizes a cost-oriented breakdown structure to provide a variety of reports on 
actual and estimated costs over the life of a project. 

Documents 

PERT General Information 
Reference 


SORT 

Produces a sequenced file of data records from random input. The internal phase 
makes use of the replacement selection sorting technique; the external phase may 
be either a balanced or poly-phase merge. The user has the option to enter own- 
code subroutines during the program. 

Documents 

General Information 
Reference 

Mass Storage SORT 

Similar to the tape SORT except that disk storage is used during intermediate 
merge processing. The SORT may optionally employ a tag sorting method. 

Documents 

General Information 
Reference 


REGINA-I 

A linear programming system; it provides an integer solution to the set of 
equations. 


Documents 

General Information 
Reference 
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ADAPT 


A system that prepares instructions for numerically controlled machine tools. 

The ADAPT language allows specification of the geometric properties of a part to 
be machined and the operations involved in producing the part, ADAPT is a subset 
of the more complex APT system. 

Documents 

General Information 
Reference 
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7. CONSOLE AND POWER CONTROL PANEL 



© Typewriter 
(D Typewriter Switches 
® Data Interchange Display 
® Index, or LJA, or CIR 
Register 

® P Register or Page Index 
File Address 


® A and Q, or E Register 
® Instruction State Register 
(ISR) 

® Operand State Register 
(OSR) 

® F or C Register 
® Status Display 

Figure 7-1. 3300 Console 


® ISR and OSR Entry Switches 
® Step Rate Control 
® Emergency Off Switch 
® Access Keyboard Switches 
® Console Condition Switches 
® Breakpoint Switch 
Assembly 
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GENERAL INFORMATION 


The 3300 desk console shown in Figure 7-1 enables the computer operator to 
control and observe computer operation. This section describes the operator's 
controls and the significance of the visual indicators. Also included in this 
section is a description of the Power Control Panel. 


CONSOLE 


The console provides an operator with visual displays to monitor the current 
status of computer, controls for setting certain conditions and performing 
operations, and a typewriter for direct input and output communications with the 
computer. Each of these areas are described in the following pages to famil¬ 
iarize the operator with the functions of the console. 


Register Displays 

Figure 7-2 shows the display locations of the operational registers described in 
Section 1. Entering data into the Communication register. Instruction State 
Register, or Operand State register is described below. 



Figure 7-2. Register Display Area 

Instruction arid Communication Registers 

The Instruction register (F register) and Communication register (C register) 
share the same display area on the console. The F register is displayed when 
the access keyboard switches are inactive and the computer is not in the GO 
mode. The C register is displayed when data is being entered via the access 
keyboard switches. 

Data entered into the A or Q registers must first pass through the Communi¬ 
cation register. Starting with the uppermost digit, data is entered into the 
Communication register by first depressing a register switch and then depres¬ 
sing the numeric keyboard switches. A blue Active Digit indicator light is 



ters, the Active Digit indicator automatically starts at the fifth digit position of 
the Communication register. 
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Depressing the TRANSFER switch causes the data to be transferred from the 
Communication register to the designated register. Immediately depressing the 
TRANSFER switch again results in transferring all zeros to the register. 


Instruction State and Operand State Registers 

The contents of the ISR or OSR may be changed by first clearing the register(s) 
and then depressing binary position switches to form the desired octal number. 
The switches may be depressed simultaneously or individually. The white 
register clearing switch and blue binary position switches are shown in Figure 
7-3, 



Figure 7-3. ISR and OSR Display and Binary Entry Switches 

Data Interchange Display 

The Data Interchange Display, shown in Figure 7-4, enables the console operator 
to determine the status of each of the eight I/O channels (0 through 7). Each 
channel has its own set of Input, Output, Reject, Interrupt,and Parity Error 
indicators. Transient conditions may not be seen on the display due to the re¬ 
sponse time of the indicators. 



Figure 7-4. Data Interchange Display 
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TABLE 7-1. DATA INTERCHANGE INDICATOR DESCRIPTIONS 


INDICATOR 

NAME 

FUNCTION 

INPUT 

Glows when data is being received by the computer on the 
channel indicated. 

OUTPUT 

Glows when data is being transmitted by the computer on the 
channel indicated. 

REJECT 

Glows when a Reject signal is received from a peripheral 
equipment on the channel indicated. 

INTERRUPT 

Glows when an Interrupt is received from a peripheral 
equipment on the channel indicated. Indicator glows until 
the interrupting condition is cleared. 

PARITY 

ERROR 

Glows when a transmission parity error has occurred on the 
channel indicated. Indicator glows until the condition is 
recognized. 


Status Display 

The Status Display provides the operator with visual indications of the internal 
status of the computer. Operating status, fault conditions, and physical mal¬ 
functions are the general status areas associated with the Status Display indi¬ 
cators. Figure 7-5 shows the arrangement of the indicators on the Status 
Display and the function of each indicator is described in Table 7-2. 
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TABLE 7-2. STATUS DISPLAY INDICATOR DESCRIPTIONS 


INDICATOR 

NAME 

FUNCTION 

STORAGE 

ACTIVE 

Indicates a storage reference is in progress. Indicator is 
common to all storage modules. 

MONITOR 

STATE 

Indicates the computer is operating in the Monitor State of 
Executive mode. 

PROGRAM 

STATE 

Indicates the computer is operating in the Program State of 
Executive mode. 

INTERRUPT 

ENABLED 

Indicates the interrupt system has been enabled by executing 
an EINT (77. 74) instruction. 

READ NEXT 
INSTRUCTION 

Indicates the computer is reading the next instruction of the 
program it is currently executing. Usually referred to as 
the RNI cycle. 

READ 

ADDRESS 

Indicates the computer is reading the lower 18 bits at a 
storage location to form a new address for indirect addres¬ 
sing. Usually referred to as the RADR cycle. 

READ 

OPERAND 

Indicates the computer is reading a 24-bit operand from 
storage for use with the instruction being executed. Usually 
referred to as the ROP cycle. 

STORE 

OPERAND 

Indicates the computer is storing a 24-bit operand that has 
been previously processed into a selected storage module. 
Usually referred to as the STO cycle. 

TEMP 

WARNING 

Indicates the temperature within the computer is abnormally 
high and is at least 80° F. 

ARITHMETIC 

OVERFLOW 

Indicates the capacity of the adder has been exceeded., Its 
capacity, including sign, is 24 or 48 bits for 24-bit pre¬ 
cision or 48-bit precision, respectively. 

DIVIDE 

FAULT 

The divide fault indicates a quotient, including sign, exceeds 
24 or 48 bits for 24-bit precision or 48-bit precision, 
respectively. Therefore, attempts to divide by too small a 
number, including positive and negative zero, result in a 
divide fault. During floating point division, a divide fault 
occurs if division by zero or by a number that is not in 
floating point format is attempted. If the divisor is not 
properly normalized a divide fault may also occur. Refer to 
Appendix B for a description of normalization. 

EXPONENT 

FAULT 

Indicates either an exponent overflow (> + 1777g) or an ex¬ 
ponent underflow « - 1777g) has occurred during a floating 
point arithmetic operation. 


(Continued) 
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TABLE 7-2. STATUS DISPLAY INDICATOR DESCRIPTIONS (Cont'd) 


INDICATOR 

NAME 

FUNCTION 

BCD 

FAULT 

Indicates a BCD fault has occurred within the BDP module 
or a SB CD (77. 72) instruction has been executed. Refer 
to Section 4, Interrupt System, for additional information. 

ILLEGAL 

WRITE 

Indicates an attempt has been made to write into a pro¬ 
tected storage location or read from certain locations 
while operating in Executive mode. Refer to Section 4, 
Interrupt System, for additional information. 

PARITY 

ERROR 

Indicates a parity error occurred during a memory 
reference. Transmission parity errors do not affect this 
indicator. 

TERMINATOR 

FAULT 

Indicates that the internal terminator power supplies are 
not functioning properly. 

CIRCUIT 

BREAKER 

Indicates that one or more of the power system circuit 
breakers are open. 

TEMP 

HIGH 

If the TEMP WARNING indicators are glowing and an 
absolute temperature of 110° F is exceeded, the computer 
automatically shuts off logic power. The TEMP HIGH 
indicator for the particular computer section continues 
to glow until the temperature drops below the absolute 
limit. Secondary power must be manually reapplied before 
normal operation can resume. 


Switches and Controls 


Condition Switches 


The condition switches are used mainly to set various operating and program¬ 
ming conditions. These 24 switches are located on both sides of the access 
keyboard switches and are shown in Figure 7-6 and described in Table 7-3, 

The typewriter control switches, located on the extreme left side of the console 
are described later in this Section. 
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Figure 7-6. Condition Switches 
TABLE 7-3. CONDITION SWITCHES DESCRIPTION 


SWITCH 

NAME 

FUNCTION 

SELECT 
JUMP (1-6) 

Switches are actuated in accordance with programs 
utilizing the Selective Jump instruction (SJl-6 OOj). 

SELECT 

STOP 

Stops the computer when the SLS (77. 70) instruction is read. 
When the computer enters the GO mode again, the program 
resumes with the next instruction. 

PARITY 

STOP 

Causes the computer to halt when a storage parity error is 
detected. 

PARITY 

INTERRUPT 

Causes the computer to process the interrupt subroutine 
when a storage parity error is detected. Refer to Section 

4 , Interrupt System, for additional information. 

EXECUTIVE 

MODE 

Permits the computer to operate in the Executive mode. 

Initial state of Executive mode is always the Monitor State. 
Reactuating this switch permits the computer to operate in 
the non-Executive mode. 

AUTO 

LOAD 

If the computer has been Master Cleared and the AUTO LOAD 
switch is actuated, the computer automatically jumps to 
address 77740 if in the non-Executive mode or address 

003700 in Executive mode and executes the instruction stored 
there. Refer to Auto Load/Auto Dump in Section 3. 

AUTO 

DUMP 

This switch performs the same function as the AUTO LOAD 
switch with the exception of jumping to address 77760 if in 
the non-Executive mode or address 003740 in Executive 
mode. 


(Continued) 
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TABLE 7-3. CONDITION SWITCHES DESCRIPTION (Cont’d) 


SWITCH 

NAME 

FUNCTION 

BDP MODE 
(Business 
Data 

Processor) 

Actuating this switch with the BDP module in the system 
permits the BDP to directly execute the business- oriented 
instructions. If the switch is not On, these instructions are 
trapped. Refer to Section 5, Instructions, for a list of the 
BDP instructions. 

AUTO 

STEP 

Permits instructions to be executed in a slow speed GO 
mode. The speed (3 to 50 instructions per second) is reg¬ 
ulated by a variable Step Rate control on the Upper Console 
Switch Panel. 

STORAGE 
CYCLE STEP 

Enables the operator to step through an instruction one 
storage cycle at a time, i. e. , RNI, RADR, ROP, or STO. 

INSTRUCTION 

STEP 

Enables the operator to execute a program, instruction by 
instruction. One instruction is executed each time the 
switch is pressed. 

THERMOSTAT 

BYPASS 

Allows computation to proceed regardless of abnormal 
temperatures within the computer. 

DISABLE 

STO PROTECT | 

Disables the protection feature of the 15 storage protect 
switches. This switch has no effect on the protected 

Auto Load and Auto Dump or program protected storage 
areas. 

ENTER AUTO 
PROGRAM 

Allows the operator to enter the Auto Load and Auto Dump 
storage areas with different data. 

LJA 

(Last Jump 
Address) 

Actuating this momentary switch when the conputer is 
stopped causes the storage address of the last jump 
instruction to be displayed on the console. 

CHANNEL 
INDEX REG 
(Channel Index 
Register) 

Pressing this switch when the computer is stopped causes 
the contents of the 3-bit Channel Index register to be dis¬ 
played. 

DISABLE 
ADVANCE P 

Prevents the P register from being incremented. When the 
GO switch on the keyboard is pressed, the same instruction 
is repeatedly executed. 

MANUAL 

INTERRUPT 

Forces the computer into an interrupt routine if the com¬ 
puter is in the GO mode. If the computer is stopped when 
the switch is pressed, it goes into an interrupt routine as 
soon as the GO switch is pressed. 

INTERNAL 

CLEAR 

Master clears internal conditions and registers. 

EXTERNAL 

CLEAR 

Master clears all external equipments and the I/O 
channels. 
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Access Keyboard 


Figure 7-7 shows the access keyboard switches, used for manually entering 
and retrieving data from the computer and controlling its operation. Table 7-4 
describes the individual keyboard switch functions. 


Upper Console Switch Panel 

The upper console switch panel shown in Figure 7-8 is used for: 
e Selecting Index register or B^ for display 

s Operating the Breakpoint switch 
0 Entering data into the ISR or OSR 
0 Adjusting the Step Rate control 

0 Immediately removing computer power in the event of an 
emergency by depressing the EMERGENCY OFF switch 

The Index register switches on the access keyboard are used for entering data. 
To display one of the three index registers, the appropriate upper console index 
register switchmustbe depressed. A. complete description of the Breakpoint switch 
follows the access keyboard switch descriptions. 



Figure 7-7. Access Keyboard Switches 
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Figure 7-8, Upper Console Switch Panel 


TABLE 7-4, ACCESS KEYBOARD SWITCHES 


SWITCH 

NAME 

FUNCTIONS 

A 

Causes both A and Q to be displayed, but permits entry 
only into A, 

Q 

Causes both A and Q to be displayed, but permits entry 
only into Q, 

E 

Causes E-q and El to be displayed. Manual entry is not 
possible. 

P 

Enables an address to be manually entered from the key¬ 
board into the P register. 

Bi, B 2 > or Bg 

Enables data to be manually entered into Index registers 

B1 , b 2, or b 3 from the keyboard. Appropriate Index 
register switch on the upper console switch panel must be 
depressed for register display. 

EN 

(ENTER) 

Permits data to-be manually entered into storage while the 
computer is stopped. First address of sequence must be 
previously entered into P. Pressing the TRANSFER 
switch advances P, 

ENTER 

PF 

Permits data to be manually entered into the Page Index 

File while the computer is stopped. First address of 
sequence must be previously entered into the lower 7 bits 
of the P register. 

SW 

(SWEEP) 

Permits unexecuted instructions to be read from consecu¬ 
tive storage locations. First address of sequence must be 
previously entered into P. Pressing the TRANSFER switch 
advances P. 

SWEEP 

PF 

Permits page indexes to be read from consecutive Page 

Index File locations. First address of sequence must be 
previously entered into the lower 7 bits of'the P register. 

SW/EN 

CONT 

(SWEEP/ENTER 

CONTINUOUS) 

Enables Sweep or Enter operations to proceed continuously 
through storage or the Page Index File without pressing the 
TRANSFER switch. 
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TABLE 7-4. ACCESS KEYBOARD SWITCHES (Cont'd) 


SWITCH 

NAME 

FUNCTION 

WRITE STO 
(WRITE 
STORAGE) 

Permits keyboard entry into the storage location specified 
by the thumb-wheel switches. Entry occurs each time the 
TRANSFER switch is pressed whether the computer is in 
the GO mode or stopped. 

READ 

STO 

(READSTORAGE) 

Permits the contents of the storage register location 
specified by the thumb-wheel switches to be displayed. The 
display rate is determined by the Step Rate control. 

GO 

Starts the program execution at the address specified by 
the P register. Not used for Sweep or Enter operations. 

STOP 

Stops the computer at the end of the current instruction. 

0 THROUGH 7 

These switches, when pressed one at a time, allow entry 
of that particular digit into the Communication register. 

TRANSFER 

Transfers data in the Communication register to a selected 
register or storage location. 

MC 

(MASTER CLEAR) 

Performs both an internal and external clear. Disabled 
when GO switch is depressed and the computer is in the 

GO mode. 

KYBD CLR 
(KEYBOARD 
CLEAR) 

Clears the Communication register. 

KYBD 

OFF 

(KEYBOARD 

OFF) 

Deactivates all access Keyboard controls. 


Breakpoint Switch 

The Breakpoint switch is a six-section, eight-position, thumb-wheel switch. 
The left-hand wheel selects the operating mode, and the other five wheels 
specify a register number or storage address. There are four mode positions 
on the mode selector switch with an OFF position between each mode; these 
modes are BPI, BPO, REG, and STO. 


BPI and BPO Modes : The address on the S Bus is continually compared with 
the instruction or operand address specified by the Breakpoint digit switches. 
When the selector switch is set to BPI, the computer stops if these values be¬ 
come equal during an RNI (Read Next Instruction) sequence. When the mode 
selector switch is set to BPO, the computer stops if these values become equal 
during an ROP (Read Operand) or STO (Store) sequence. 
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REG and STO Modes: In these two modes, the operator may either monitor the 
contents of a register location or storage address specified by the thumb-wheel 
digit switches, or he may store a word in these locations. To monitor a storage 
location: 

• Set the mode selector to REG (register file location) or STO (storage). 

e Set the Breakpoint switch to the desired register number or storage 
address. 

• Press the READ STO switch on the keyboard. 

• Adjust the Step Rate control to vary the display rate. 

The register or storage contents are repeatedly displayed in the Communication 
register at the selected repetition rate until another keyboard button is pressed 
to release READ STO. To write a word in storage: 

e Set the mode selector to REG or STO. 

• Set the Breakpoint switch to the desired register number or storage 
location. 

• Press the WRITE STO switch on the keyboard. 

• Enter data into the Communication register by depressing the numeric 
switches and finally the TRANSFER switch. 

The data is entered into the desired storage location or Register File location 
at the end of the instruction that is currently being executed by the computer. 
Pressing any other register or mode selector switch releases WRITE STO 
operation. 


Emergency Off Switch 

This red momentary switch is used to remove power from the whole computer 
system in case of a fire or other emergency. It should not be used for a normal 
power shutdown. Refer to the SOURCE POWER OFF switch description in the 
Power Control Panel description of this section. 


Console Loudspeaker Volume Control 


The console loudspeaker and its associated volume control are mounted under¬ 
neath the console table. The loudspeaker receives its input from the upper 3 bits 
of the A register. Sound is produced when one or more of these bits are toggled 
at an audio frequency. Loudspeaker volume is controlled by rotating the volume 
control knob. 


Examples of Keyboard Switch Functions : 

1. To enter data into the A register: 
a. Depress the A register switch. 
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b. Enter all eight digits of the Communication register by depressing 
the appropriate numeric key switches.* 

c. Depress the TRANSFER switch. 

d. Depress the KEYBOARD OFF switch. 

2. To enter data into the Q register: 

Depress the Q register switch and repeat steps b through d 

of example 1. 

3. To enter the Program Address Counter (P register) with a 

specific address: 

a. Depress the P register switch, 

b. Enter the lower five digits of the Communication register by 
depressing the appropriate numeric key switches. 

c. Depress the TRANSFER switch. 

d. Depress the KEYBOARD OFF switch. 

4. To enter an operand at a specific address:** 

a. Perform example 3. 

b. Depress the EN switch. 

c. Enter all eight digits of the Communication register by 
depressing the appropriate numeric key switches. 

d. Depress the TRANSFER switch. 

e. The count in the Program Address Counter has now incre¬ 
mented by one. If data is to be entered into this memory 
location, repeat steps c and d for as many succeeding 
entries as required. 

f. Depress the KEYBOARD OFF switch when all data has 
been entered into the successive group of memory 
locations. 

5. To read an operand from a specific storage address: 

a. Perform example 3. 

b. Depress the SW switch. 

c. Depress the TRANSFER switch. 

d. The contents of the specified storage address are now displayed 
in the Communication register. (The Program Address Counter 
is not incremented when the TRANSFER switch is initially 
depressed.) 


*If all eight digit positions of the Communication register are not entered 
before the Transfer switch is depressed, zeros will be entered into the 
remaining digit positions. 

*The Breakpoint switch may be used in lieu of this operation. (Refer to 
Example d. Figure 7-9.) 
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e. If the TRANSFER switch is again depressed, the Program 
Address Counter is incremented by one, and the contents of 
the new address are displayed. 

f. Depress the KEYBOARD OFF switch when all of the desired 
memory locations within a successive group have been 
examined. 

NOTE 

Step 5 only permits the operator to examine 
the contents of specific storage locations. 

The instructions are not executed during 
this operation. 

6. To enter zeros or another operand into all storage locations: 

a. Depress the EN switch. 

b. Enter all eight digits of the Communication register by 
depressing the appropriate numeric key switches. 

c. Depress the SW/EN CONT switch. 

d. Depress the STOP switch. 

e. Depress the KEYBOARD OFF switch. 

7. The following procedure is applicable for sweeping storage during 

certain maintenance routines: 

a. Depress the SW switch. 

b. Depress the SW/EN CONT switch. This switch remains 
engaged until the STOP switch is depressed. 

c. Depress the STOP switch. 

d. Depress the KEYBOARD OFF switch. 

8. To enter a 12-bit operand into a specific Page Index File (PIF) 

address: 

a. Set P to a specific PIF address (000-177) as outlined in 
example 3. (Only the lower 7-bits of P are recognized.) 

b. Depress the ENTER PF switch. 

c. Enter the lower four digits of the Communication register by 
depressing the appropriate numeric key switches. 

d. Depress the TRANSFER switch. 

e. The PIF address in the Program Address Counter has now 
incremented by one. If data is to be entered into this PIF 
location, repeat steps c and d for as many succeeding 
entries as required. 

f. Depress the KEYBOARD OFF switch when all data has been 
entered into the successive group of PIF locations. 

9. To read an index from the PIF: 

a. Perform step a of example 8. 

b. Depress the SWEEP PF switch 


Rev. A 


7-14 



c. Depress the TRANSFER switch. 

d. The specified index of the PIF is now displayed in the lower 
12-bits of the Conamunication register. (The Program Address 
Counter is not incremented when the TRANSFER switch is 
initially depressed.) 

e. If the TRANSFER switch is again depressed, the Program 
Address Counter is incremented by one and the index of the 
new PIF address is displayed. 

f. Depress the KEYBOARD OFF switch when all of the desired 
indexes within a successive group have been examined. 

10. To enter zeros or another operand into all indexes of the PIF; 

a. Depress the ENTER PF switch 

b. Enter the lower four digits of the Communication register by 
depressing the appropriate numeric key switches. 

c. Depress the SW/EN CONT switch. This switch remains 
engaged until the STOP switch is depressed. 

d. Depress the KEYBOARD OFF switch. 

11. The following procedure is applicable for sweeping all indexes of 

the PIF during certain maintenance routines: 

a. Depress the SWEEP PF switch 

b. Depress the SW/EN CONT switch. This switch remains 
engaged until the STOP switch is depressed. 

c. Depress the STOP switch. 

d. Depress the KEYBOARD OFF switch. 

Examples of Console Switch Functions; 

1. To enter a special routine into the non-Executive mode Auto Load 

storage area; 

a. Depress the MC (Master Clear) keyboard switch. 

b. Holding down the keyboard STOP switch, depress the AUTO 
LOAD switch. Release both switches. The P register should 
now read 77740. (Holding the STOP switch down prevents the 
computer from entering the GO mode and executing the pre¬ 
vious Auto Load routine.) 

c. Depress the ENTER AUTO PROGRAM switch. 

d. Depress the keyboard EN switch. 

e. Enter the first instruction of the new routine at address 
77740 by depressing the appropriate numeric key switches. 

f. Depress the keyboard TRANSFER switch. 

g. Repeat steps e and f for addresses 77741 through 77757. 

h. Depress the MC switch. This clears the registers and cancels 
the ENTER AUTO PROGRAM function. 
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i. Depress the KEYBOARD OFF switch. 

2. To enter a special routine into the non-Executive mode 
Auto Dump storage area: 

Repeat steps a through i of example 1 using the AUTO DUMP 
switch and filling the storage area covered by addresses 77760 
through 77777. 

3. To execute the Auto Load routine: 

a. Depress the keyboard MC switch. 

b. Depress the AUTO LOAD switch. The computer automatically 
executes the Auto Load routine and stops when a stop or halt 
instruction is recognized. The Auto Load function is auto¬ 
matically cleared when the first I/O operation is completed. 

4. To execute the Auto Dump routine: 

Perform steps a and b in example 3 but use the AUTO DUMP 
switch instead of the AUTO LOAD switch. 

5. To execute a program at a Auto Step rate: 

a. Set the P register to the first address of the program to be 
executed. 

b. Depress the AUTO STEP switch. 

c. Adjust the STEP RATE display control. 

d. Depress the AUTO STEP switch again to cancel the function 
and stop program execution. The only way to exit from the 
Auto Step mode is to depress the AUTO STEP switch again. 

In the Auto Step mode, halt and jump instructions are 
executed.but the computer does not stop. Neither will program 
execution be affected by depressing the STOP switch. The 
computer continues cycling through memory until the AUTO 
STEP switch is again depressed, 

NOTE 

To load or execute a subroutine in the Auto 
Load or Auto Dump areas while in Executive 
mode^ perform the same operations as for 
non-Executive mode except that the addresses 
for the respective areas will be as follows: 

Auto Load: 003700 through 003737 

Auto Dump: 003740 through 00377 7 
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EXAMPLE A 


EXAMPLE B 



The Breakpoint switch is inoperative 
whenever an OFF designator is dis¬ 
played. An OFF designator separ¬ 
ates the REGj STO, BPI and BPO 
positions. 



During the normal execution of a 
program, the computer stops when 
an RNI is attempted at memory lo¬ 
cation 05443. A jump to this loca¬ 
tion also causes the computer to stop. 
If the program references memory 
location 05443 for an operand, the 
computer ignores the Breakpoint 
switch. 


EXAMPLE C 



The computer stops only when an 
attempt is made to read or store an 
operand at address 00413. 


EXAMPLE D 



If the WRITE STO switch on the key¬ 
board is depressed and data has been 
entered into the Communication reg¬ 
ister, the data is transferred to 
memory location 00104 when the 
TRANSFER switch is depressed. 


Figure 7-9. Breakpoint Switch Examples 
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EXAMPLE E 


EXAMPLE F 



If the WRITE STO switch on the 
keyboard is depressed and data has 
been entered into the Communi¬ 
cation register, the data will be 
transferred to register 77 when the 
TRANSFER switch is depressed. 
(Only the lower two digits are re¬ 
cognized when the designator switch 
is in the REG position. The pro¬ 
grammer must use caution when 
writing into the Register File to 
prevent destruction of other data. 
Refer to Section 1, Table 1-3.) 


\ Z T 6 0 4 


If the READ STO switch on the key¬ 
board is depressed, the contents of 
memory location 27004 are displayed 
in the Communication register at a re¬ 
petition rate determined by the Step 
Rate control. (If the memory location 
depicted by the Breakpoint switch ex¬ 
ceeds the storage capacity of the sys¬ 
tem, the computer selects the address 
that corresponds to the storage capa¬ 
city of the system.) 


EXAMPLE G 



If the READ STO switch on the key¬ 
board is depressed, the contents of 
register 22 are displayed in the 
Communication register at a repe¬ 
tition rate determined by the Step 
Rate control. (Only the lower two 
digits are of consequence when the 
REG designator is displayed. In 
this case register 22, the real time 
clock, is being referenced.) 


Figure 7-9. Breakpoint Switch Examples (Cont'd) 
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1758 


Typewriter 


The console typewriter is an on-line input/output (I/O) device; i.e. , it requires 
no connection to a communication channel and no function codes are issued. The 
typewriter receives output data directly from storage via the lower 6 bits of the 
Data Bus. Inputs to storage are handled in the same manner. 

Used in conjunction with Block Control and the Register File, the typewriter may 
be used to enter a block of internal binary-coded characters into storage and to 
print out data from storage. The two storage addresses that define the limits of 
the block must be stored in the register file prior to an input or output operation. 
Register 23 contains the program state number and the initial character address 
of the block. Register 33 contains the last character address, plus one (refer to 
Section 1, Table 1-1 notes for Registers 23 and 33 operand formats). Because 
the initial character address is incremented for each storage reference, it always 
shows the address of the character currently being stored or dumped. Output 
operations occur at the rate of 15 characters per second. Input operations are 
limited by the operator's typing speed. 

The console tynewriter control switches are shown InFigure 7-10 and their 
functions are described in Table 7-5. 



Figure 7-10. Console Typewriter Control Switches 
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The general order of events when using the console typewriter for an input or 
output operation is: 

• Check status 

• Set registers 23 and 33 of the Register File to the appropriate 
addresses 

• Set tabs, margins and spacing; turn on typewriter 

• Clear 

• Type out or type in 


Status Checking 


The programmer may wish -^o check the status of the typewriter before pro¬ 
ceeding. This is done with the Pause instruction. Status response is returned 
to the computer via two status lines. 

The typewriter control transmits two status signals that are checked by the Busy 
Comparison Mask using the Pause instruction. These status signals are: 

Bit 09 Type Finish 

Bit 10 Type Repeat 

An additional status bit appears on sense line 08. This code is Type Busy and 
is transmitted by block control in the computation section when a typewriter 
operation has been selected. If the programmer is certain of the status of the 
typewriter, this operation may be omitted. 


Set Registers 23 and 33 


Registers 23 and 33 define the limits of the typewriter I/O operation. These 
registers are set by instruction or by entering the registers via the Breakpoint 
switch. 


Set Tabs, Margins, and Spacing 


All tabs, margins, and paper spacing must be set manually prior to the input or 
output operation. A tab may be set for each space on the typewriter between 
margins. 


Clear 


There are three types of Clears which may be used to clear all conditions (ex¬ 
cept Encode Function) existing in the typewriter control. These are: 

• Internal Clear or a Master Clear 

This signal clears the typewriter control and sets the type¬ 
writer ,to lower case. 
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TABLE 7-5. CONSOLE TYPEWRITER SWITCHES AND INDICATORS 


SWITCH 

SWITCH (S) 
INDICATOR (I) 

FUNCTION 

ENCODE 

FUNCTION 

S/I 

This switch enables the typewriter to send 
to storage the special function codes for 
backspace, tab, carriage return, upper¬ 
case shift, and lower-case shift. 

TYPE 

LOAD 

S/I 

This switch allows the computer to receive 
a block of input data from the typewriter. 

The TYPE LOAD indicator remains on until 
either the FINISH, REPEAT, or CLEAR but¬ 
ton is pressed, or until the last character of 
the block has been stored. If the program 
immediately reactivates the typewriter, it 
may appear that the light does not go off. 

TYPE 

DUMP 

S/I 

This switch causes the computer to send 
data to the typewriter for print-out. It is a 
momentary contact switch that is illuminated 
until the last character in the block has been 
printed or the CLEAR button is pressed. 

REPEAT 

S/I 

This switch is pressed during a Type Load 
operation to indicate that a typing error 
occurred. This switch deactivates busy 
sense line 10 (see PAUS instruction). If 
the computer does not respond, this light 
remains on. 

FINISH 

S/I 

This switch is pressed during a Type Load- 
operation to indicate that there is no more 
data in the current block. This action is 
necessary if the block that the operator 
has entered is smaller than the block de¬ 
fined by registers 23 and 33. This switch 
also deactivates busy sense line 09. If the 
computer does not respond, this light 
remains on. 

CLEAR 

S/I 

This switch clears the typewriter controls 
and sets the typewriter to lower case but 
does not cancel the ENCODE FUNCTION 
switch. 
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• Clear Channel, Search/Move Control, or Type Control 
instruction (77.51). 

This instruction selectively clears a channel, the S/M control, 
or, by placing a "l" in bit 08 of the instruction, the typewriter 
control, and sets the typewriter to lower case. 

• Clear Switch on Typewriter 

This switch clears the typewriter control and sets the 
typewriter to lower case. 

Type In and Type Load 


Executing the CTI (77. 75) instruction or pressing the TYPE LOAD switch on the 
console or typewriter permits the operator to enter data directly into storage 
from the typewriter. When the TYPE LOAD indicator on the console glows, the 
operator may begin typing. The Encode Function switch must be depressed to 
enable backspace, tab, carriage return, and case shifts to be transmitted to the 
computer during a typewriter input operation. 

Input is in character mode only. As each character is typed, the information 
is transmitted via the Data Bus to the storage address specified by block control. 
This address is incremented as characters are transmitted. When the current 
address equals the terminating address, the TYPE LOAD indicator goes off and 
the operation is terminated. Data is lost if the operator continues typing after 
the TYPE LOAD indicator goes off. 


Type Out and Type Dump 


The typewriter begins to type out when the computation section executes a CTO 
(77. 76) instruction,or when the operator presses the TYPE DUMP switch on the 
console. Single 6-bit characters are sent from storage to the typewriter via the 
lower 6 bits of the Data Bus. When the current address equals the terminating 
address, the TYPE DUMP indicator goes off and the operation is terminated. 

During a Type Out operation, the keyboard is locked to prevent loss of data in 
the event a key is accidentally pressed. 

Table 7-6 lists the internal BCD codes, typewriter printout and upper-or lower¬ 
case shift that applies to the console typewriter. All character transmission 
between the computation section and the typewriter is in the form of internal 
BCD. The typewriter logic makes the necessary conversion to the machine 
code. 
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NOTE 

Shifting to upper case (57) or lower case (32) 
is not necessary except on keyboard letters 
where both upper and lower cases are avail¬ 
able. The standard type set has two sets of 
upper case letters and no lower case letters. 
This eliminates the need for specifying a 
case shift. 


TABLE 7-6. CONSOLE TYPEWRITER CODES 


PRINT¬ 

OUT 

CASE 

INTERNAL 
BCD CODE 

PRINT¬ 

OUT 

CASE 

INTERNAL 
BCD CODE 

0 

L* 

00 

- 

L 

40 

1 

L 

01 

J 

U or L 

41 

2 

L 

02 

K 

U or L 

42 

3 

L 

03 

L 

U or L 

43 

4 

L 

04 

M 

U or L 

44 

5 

L 

05 

N 

U or L 

45 

6 

L 

06 

O 

U or L 

46 

7 

L 

07 

P 

U or L 

47 

8 

L 

10 

Q 

U or L 

50 

9 

L 

11 

R 

U or L 

51 

± 

u* 

12 

° (degree) 

U 

52 

= 

L 

13 

$ 

u 

53 


U 

14 

* 

u 

54 


U 

15 

# 

u 

55 


L 

16 

% 

u 

56 

? 

U 

17 

(Shift to UC) 


57 

+ 

u 

20 

(Space) 


60 

A 

U or L 

21 

/ 

L 

61 

B 

U or L 

22 

S 

U or L 

62 

C 

U or L 

23 

T 

U or L 

63 

D 

U or L 

24 

U 

U or L 

64 

E 

U or L 

25 

V 

U or L 

65 

F 

U or L 

26 

W 

U or L 

66 

G 

U or L 

27 

X 

U or L 

67 

H 

U or L 

30 

Y 

U or L 

70 

I 

U or L 

31 

Z 

U or L 

71 

(Shift to LC) 


32 

& 

U 

72 


U and L 

33 


U and L 

73 

) 

U 

34 

( 

U 

74 

1 

L 

35 

(Tab) 


75 

@ 

U 

36 

(Backspace) 


76 

! 

L 

37 

(Carriage 






Return) 


77 



Lower Case; U = Upper Case 
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POWER CONTROL PANEL 


The Power Control Panel module shown in Figure 7-11 controls the logic power 
supplied to the CPU and the first I/O module. Adjusting the +20 and -20 con¬ 
trols for 0% indication on. their respective meters provides exactly the proper 
operating power. The following illustration shows which part of the computer 
the Compute One and Compute Two controls govern. 


FLOATING 

POINT 

MODULE 


I_ 



■V 
POWER 
CONTROLLED 
BY 

COMPUTE 2 


V 
POWER 
CONTROLLED 
BY 

COMPUTE I 


I/O 

MODULE 


_I 


The two main circuit breakers must both be On before the system CPU is 
operative. Refer to the 3300 Customer Engineering manual for detailed main¬ 
tenance information. 


Elapsed Time Meters 

Two elapsed time meters and a key-operated, two-position switch are located 
on the control panel. Turning the key-operated Maintenance Mode switch to ON 
connects the Maintenance Time meter to the computer to record the amount of 
time the computer is used during a maintenance period. Removing the key con¬ 
nects the Operating Time meter to the computer to record normal operating 
time. Customers renting the computer are often billed according to the time 
recorded on this meter. The sum of the times recorded on both meters indi¬ 
cates the total computer running time. Only one of the two meters can operate 
at any one time. Either meter is active for a minimum of one second when a 
storage cycle occurs. 


Storage Protect Switches 

The 15 Storage protect switches are described in Section 2. 


Rev. A 


7-24 








APPENDIX A 


CONTROL DATA 3100, 3200, 3300 COMPUTER SYSTEMS 

CHARACTER SET AND 
BCD/ASCII CODE CONVERSIONS 




CONTROL DATA 3100, 3200, 3300 COMPUTER SYSTEMS 

CHARACTER SET 


INTERNAL 

BCD 

CODES 

EXTERNAL 

BCD 

CODES 

CONSOLE TYPEWRITER 
CHARACTERS (USES 
INTERNAL BCD ONLY) 

MAGNETIC 
TAPE UNIT 
CHARACTERS 

PUNCHED 

CARD 

CODES 

00 

12 

0 (zero) 

0 (zero) 

0 

01 

01 

1 

1 

1 

02 

02 

2 

2 

2 

03 

03 

3 

3 

3 

04 

04 

4 

4 

4 

05 

05 

5 

5 

5 

06 

06 

6 

6 

6 

07 

07 

7 

7 

7 

10 

10 

8 

8 

8 

11 

11 

9 

9 

9 

12 

(illegal) 

± 

— 

2,8 

13 

13 

= 

# 

3. 8 

14 

14 

1? 

@ 

4, 8 

15 

15 


— 

5, 8 

16 

16 


— 

6, 8 

17 

17 

9 

(file mark) 

7.8 

20 

60 

+ 

& 

12 

21 

61 

A 

A 

12, 1 

22 

62 

B 

B 

12, 2 

23 

63 

C 

C 

12, 3 

24 

64 

D 

D 

12, 4 

25 

65 

E 

E 

12, 5 

26 

66 

F 

F 

12, 6 

27 

67 

G 

G 

12, 7 

30 

70 

H 

H 

12, 8 

31 

71 . 

I 

I 

12, 9 

32 

72., 

(Shift to 
lower case) 

+0 

12, 0 

33 

73 

.(period) 

, 

12, 3, 8 

34 

74 

) 

H 

12,4,8 

35 

75 

'(apostrophe) 

— 

12, 5, 8 

36 

76 

@ 

— 

12, 6, 8 

37 

77' 

! 


12, 7, 8 


(Continued on next page) 
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INTERNAL 

EXTERNAL 

CONSOLE TYPEWRITER 

MAGNETIC 

PUNCHED 

BCD 

BDC 

CHARACTERS (USES 

TAPE UNIT 

CARD 

CODES 

CODES 

INTERNAL BCD ONLY) 

CHARACTERS 

CODES 


-(minus) 

J 

K 

L 

M 

N 

O 

P 

Q 

R 

° (degree) 


# 

% 

(Shift to 
upper case) 

(space) 

/ 

5 
T 
U 

V 

w 

X 

Y 

z 

6 

, (comma) 

( 

(tab) 

(backspace) 
(carriage return) 


-(minus) 

J 


(blank) 

/ 

S 

T 

U 

V 
W 
X 

Y 
Z 

, (comma) 

% 


11 

. 1,1 
. 1,2 
.1,3 
,1,4 
.1,5 
. 1,6 
. 1 , 7 
. 1,8 
. 1 , 9 
. 1,0 
. 3, 8 
,4,8 
11, 5, 8 
11 , 6 , 8 
11, 7,8 

(blank) 
0 , 1 
0.2 
0.3 
0.4 
0,5 
0 , 6 
0. 7 
0,8 
0, 9 
0 , 2 , 8 
0, 3, 8 
0. 4,8 
0, 5, 8 
0, 6, 8 
0, 7, 8 
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BCD/ASCII CONVERSION TABLE 
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BCD/ASCII CONVERSION TABLE (Cont'd) 


6-BIT 
BCD CODE 

-i 

8-BIT 
ASCII 

CHARACTER 


7* 

40 

- 

0 

41 

J 

0 

42 

K 

0 

43 

L 

0 

44 

M 

0 

45 

N 

0 

46 

O 

0 

47 

P 

0 

50 

Q 

0 

51 

R 

0 

52 

! 

0 

53 

$ 

0 

54 

>1= 

0 

55 

# 

0 

56 

\ 

0 

57 

> 

0 

60 

Blank 

0 

61 

/ 

0 

62 

S 

0 

63 

T 

0 

64 

U 

0 

65 

V 

0 

66 

W 

0 

67 

X 

0 

70 

Y 

0 

71 

Z 

0 

72 

] 

0 

73 

Comma 

0 

74 

( 

0 

75 

~ 

0 

76 


0 

77 

? 

0 



*ASCII bit 7 is unassigned and "O" for all codes. 
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APPENDIX B 


SUPPLEMENTARY ARITHMETIC INFORMATION 



B. SUPPLEMENTARY ARITHMETIC INFORMATION 


NUMBER SYSTEMS 

Any number system may be defined by two characteristics, the radix or base 
and the modulus. The radix or base is the number of unique symbols used in 
the system. The decimal system has ten symbols, 0 through 9. Modulus is 
the number of unique quantities or magnitudes a given system can distinguish. 
For example, an adding machine with ten digits, or counting wheels, would 
have a modulus of IQlO-l. The decimal system has no modulus because an 
infinite number of digits can be written, but the adding machine has a modulus 
because the highest number which can be expressed is 9, 999, 999, 999. 

Most number systems are positional; that is, the relative position of a symbol 
determines its magnitude. In the decimal system, a 5 in the units column 
represents a different quantity than a 5 in the tens column. Quantities equal 
to or greater than 1 may be represented by using the 10 symbols as coefficients 
of ascending powers of the base 10. The number 984io is: 

9 X 10^ = 9 X 100 = 900 

+8 X 10^ = 8 X 10 = 80 

+4 X 10^ = 4 X 1 = 4 

984io 

Quantities less than 1 may be represented by using the 10 symbols as co¬ 
efficients of ascending negative powers of the base 10. The number 0. 593]^0 
may be represented as; 

5 X 10“^ = 5 X . 1 = . 5 

+9 X 10-2 = 9 X . 01 = . 09 

+3 X 10-8 = 3 X . 001 = ■ 003 

0. 593;^Q 

Binary Number System 


Computers operate faster and more efficiently by using the binary 
system. There are only two symbols, 0 and 1; the base = 2. The 
shows the positional value; 


2 ^ 

32 


2 ^ 2 ^ 2 ^ 

16 8 4 


2 ^ 

1 


Binary point 


number 

following 


B-1 


Rev. A 



The binary number 0 110 10 represents: 

0x2^ = 0x32= 0 

+1x2^^= 1x16 = 16 
+1x2^ = 1x8 = 8 

+0x2^ = 0x4 = 0 

+1 X 2^ = 1 X 2 = 2 

+0x2° = 0x1 = 0 

26io 

Fractional binary numbers may be represented by using the symbols as co¬ 
efficients of ascending negative powers of the base. 

2 2 2 2 2 . 

Binary Point 1/2 1/4 1/8 1/16, 1/32 

The binary number 0. 10 110 may be represented as: 

1 X 2 = 1 x 1/2 =1/2 = 8/16 

+0x2 "^ = 0x1/4 = 0 =0 

+1 X 2 "'^ = 1 X 1/8 = 1/8 = 2/16 
+1 X 2 = 1 X 1/16 = 1/16 = 1/16 

iTTTeio 


Octal Number System 


The octal number system uses eight discrete symbols, 0 through 7. With base 


eight the positional value is: 


8'^ 84 

o 

CO 

CO 

(M 

CO 

00 

CO 

32,768 4,096 

512 64 8 1 

The octal number 5138 represents: 


5 X 82 = 5 X 64 = 

320 

+1x81 = 1x8 = 

8 

+3 X 8° = 3 X 1 = 

3 


33110 


Fractional octal numbers may be represented by using the symbols as co¬ 
efficients of ascending negative powers of the base. 

8 8"2 8 "^ 8 "^ . . . 

1/8 1/64 1/512 1/4096 


The octal number 0. 4520 represents; 

4x8 = 4x1/8 = 256/512 

+5 X 8 “2 = 5 X 1/64 = 40/512 
+2x8 "^ = 2 X 1/512 = 2/512 

298/512 = 149/256io 
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ARITHMETIC 


Addition and Subtraction 

Binary numbers are added according to the following rules: 

0+0 = 0 
0 + 1 = 1 
1 + 0=1 

1+1 = 0 with a carry of 1 

The addition of two binary numbers proceeds as follows (the decimal equivalents 
verify the result); 


Augend 

0111 

(7) 

Addend 

+0100 

+(4) 

Partial Sum 

0011 


Carry 

1 


Sum 

1011 

(11) 


Subtraction may be performed as an addition; 

8 (minuend) 8 (minuend) 

-6 (subtrahend) or (lO's complement of subtrahend) 

2 (difference) 2 (difference - omit carry) 

The second method shows subtraction performed by the "adding the complement" 
method. The omission of the carry in the illustration has the effect of reducing 
the result by 10. 


One's Complement: The computer performs all arithmetic and counting 
operations in the binary one's complement mode. In this system, positive 
numbers are represented by the binary equivalent and negative numbers in ones' 
complement notation. 

The one's complement representation of a number is found by subtracting each 
bit of the number from 1. For example: 

nil 

- 1001 9 

0110 (one's complement of 9) 

This representation of a negative binary quantity may also be obtained by sub¬ 
stituting "I's" for "O's" and "O's" for "I's". 

The value zero can be represented in one's complement notation in two ways: 

0000 “*‘002 Positive (+) Zero 
nil ”*‘112 Negative (-) Zero 

The rules regarding the use of these two forms for computation are: 

• Both positive and negative zero are acceptable as arithmetic operands. 

• If the result of an arithmetic operation is zero, it will be expressed as 
positive zero. 


B-3 


Rev. A 



One's complement notation applies not only to arithmetic operations performed 
in A, but also to the modification of execution addresses in the F register. 
During address modification, the modified address will equal IIIIIq only if the 
unmodified execution address equals 777770 and b = 0 or (B^’) = 777770. 


Multiplic ati on 


Binary multiplication proceeds according to the following rules: 

0x0 = 0 
0x1=0 
1x0=0 
1x1 = 1 


Multiplication is always performed on a bit-by-bit basis. Carries do not result 
from multiplication, since the product of any two bits is always a single bit. 


Decimal example: 


Multiplicand 
Multiplier 
Partial Products 

Product 


f 


14 
12 
28 
14 
16810 


(shifted one place left) 


The shift of the second partial product is a shorthand method for writing the 
true value 140. 


Binary example: 


Multiplicand (14) 
Multiplier (12) 


Partial Products i 


1110 

1100 

0000 

0000 

1110 

1110 


shift to place 
digits in proper 
columns 


Product (168 ^q) IOIOIOOO 2 


The computer determines the running subtotal of the partial products. Rather 
than shifting the partial product to the left to position it correctly, the com¬ 
puter right shifts the summation of the partial products one place before the 
next addition is made. When the multiplier bit is "l", the multiplicand is 
added to the running total and the results are shifted to the right one place. 
When the multiplier bit is "O", the partial product subtotal is shifted to the 
right (in effect, the quantity has been multiplied by 102 ). 


Division 


The following examples shows the familiar method of decimal division: 
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14 

Divisor 13 I 185 
13 
55 
52 
3 


Quotient 

Dividend 

Partial Dividend 

Remainder 


The computer performs division in a similar manner (using binary equivalents): 


1110 

Divisor 1101 |10111001 
1101 
10100 
1101 
1110 
1101 
11 


Quotient (14) 
Dividend 


Partial Dividends 
Remainder (3) 


However, instead of shifting the divisor right to position it for subtraction from 
the partial dividend (shown above), the computer shifts the partial dividend left, 
accomplishing the same purpose and permitting the arithmetic to be performed 
in the A register. The computer counts the number of shifts, which is the 
number of quotient digits to be obtained; after the correct number of counts, the 
routine is terminated. 


CONVERSIONS 

The procedures that may be used when converting from one number system to 
another are power addition, radix arithmetic, and substitution. 


TABLE B-1. RECOMMENDED CONVERSION PROCEDURES 
(INTEGER AND FRACTIONAL) 


Conversion 

Recommended Method 

Binary to Decimal 

Octal to Decimal 

Decimal to Binary 

Decimal to Octal 

Binary to Octal 

Octal to Binary 

Power Addition 

Power Addition 

Radix Arithmetic 

Radix Arithmetic 
Substitution 

Substitution 

GENERAL RULES 

r. > r„ : use Radix Arithmetic, Substitution 
r|^ < ri : use Power Addition, Substitution 
r^ = Radix of initial system 
r^ = Radix of final system 
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Power Addition 


To convert a number from r^^ to rf (rj^ <rf) write the number in its expanded rj^ 
polynomial form and simplify using r^ arithmetic. 

EXAMPLE 1 Binary to Decimal (Integer) 

010 III 2 = 1(2“^) +0(2^) +1(22) +i(2l) +1(2°) 

= 1(16) +0(8) +1(4) +1(2) +1(1) 

= 16 +0 +4 +2 +1 

= 23;^q 

EXAMPLE 2 Binary to Decimal (Fractional) 

. OlOlo = 0(2’1) +1(2'2) +0(2"^) +1(2"'^) 

+1/16 

(Integer) 


(Fractional) 

. 44o = 4(8-1) +4(8-2) 

= 4/8 +4/64 

= 36/64io 
= 9 /I 610 

Radix Arithmetic 

To convert a whole number from rj^ to rf (r^ >rf): 

• Divide r^ by rf using r^ arithmetic 

• The remainder is the lowest order bit in the new expression 

• Divide the integral part from the previous operation by rf 

• The remainder is the next higher order bit in the new expression 

• The process continues until the division produces only a remainder 
which will be the highest order bit in the r^ expression. 

To convert a fractional number from r^ to r^; 

• Multiply r^ by rf using r^ arithmetic 

• The integral part is the highest order bit in the new expression 

• Multiply the fractional part from the previous operation by rf 

• The integral part is the next lower order bit in the new expression 

• The process continues until sufficient precision is achieved or the 
process terminates. 


= 0 +1/4 +0 

= 5/16j„ 

EXAMPLE 3 Octal to Decimal 

324o = 3(82) +2(8l) +4(8®) 

= 3(64)+2(8) +4(1) 

= 192 +16 +4 


EXAMPLE 4 Octal to Decimal 
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EXAMPLE 

1 Decimal to Binary (Integer) 

45 - 

- 2 

= 22 

remainder 1; record 

1 

22 - 

- 2 

= 11 

remainder 0; record 

0 

11 - 

- 2 

= 5 

remainder 1; record 

1 

5 - 

- 2 

= 2 

remainder 1; record 

1 

2 - 

- 2 

= 1 

remainder 0; record 

0 

1 - 

- 2 

= 0 

remainder 1; record 

1 

Thus: 

'^^lO 

= IOIIOI 2 

101101 


EXAMPLE 2 Decimal to Binary (Fractional) 

. 25 X 2 = 0. 5; record 0 
.5 X 2 = 1. 0; record 1 
. 0 X 2 = 0. 0; record 0 

Thus: . 25 j^q = . OIO 2 • 010 

EXAMPLE 3 Decimal to Octal (Integer) 


273 -^8 = 34 remainder 1; record 1 

34 -^-8 = 4 remainder 2; record 2 

4 ■i-8 = 0 remainder 4; record 4 

Thus: 273 ^q = 421g 421 


EXAMPLE 4 Decimal to Octal (Fractional) 

. 55 X 8 = 4. 4; record 4 
.4 X 8 = 3. 2; record 3 
.2 X 8 = 1. 6; record 1 


. 431 . . . 

Thus: • 55 ^q = . 431. . . g 


Substitution 


This method permits easy conversion between octal and binary representations 
of a number. If a number in binary notation is partitioned into triplets to the 
right and left of the binary point, each triplet may be converted into an octal 
digit. Similarly, each octal digit may be converted into a triplet of binary digits. 

EXAMPLE 1 Binary to Octal 

Binary = 110 000 . 001 010 
Octal =60.1 2 

EXAMPLE 2 Octal to Binary 

Octal = 6 5 0.2 2 7 

Binary = 110 101 000 . 010 010 111 
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FIXED POINT ARITHMETIC 


24-Bit Precision 


Any number may be expressed in the form kB'^, where k is a coefficient, B a 
base number, and the exponent n the power to which the base number is raised. 

A fixed point number assumes; 

• The exponent n = 0 for all fixed point numbers. 

• The coefficient, k, occupies the same bit positions within the computer 
word for all fixed point numbers. 

• The radix (binary) point remains fixed with respect to one end of the 
expression. 

A fixed point number consists of a sign bit and coefficient as shown below. The 
upper bit of any fixed point number designates the sign of the coefficient (23 
lower order bits). If the bit is "l", the quantity is negative since negative 
numbers are represented in one's complement notation; a "O” sign bit signifies 
a positive coefficient. 

23 22 _ 00 

COEFFICIENT I 


SIGN BIT 

The radix (binary) point is assumed to be immediately to the right of the lowest 
order bit (00). 

In many instances, the values in a fixed point operation may be too large or too 
small to be expressed by the computer. The programmer must position the 
numbers within the word format so they can be represented with sufficient pre¬ 
cision. The process, called scaling, consists of shifting the values a pre¬ 
determined number of places. The numbers must be positioned far enough to 
the right in the register to prevent overflow but far enough to the left to main¬ 
tain precision. The scale factor (number of places shifted) is expressed as the 
power of the base. For example, 5, 100, OOOiq may be expressed as 0. 51 x 
lO"^, 0.051 X 108, 0.0051 X 109, etc. The seme factors are 7, 8, and 9. 

Since only the coefficient is used by the computer, the programmer is res¬ 
ponsible for remembering the scale factors. Also, the possibility of an over¬ 
flow during intermediate operations must be considered. For example, if two 
fractions in fixed point format are multiplied, the result is a number <1. If 
the same two fractions are added, subtracted, or divided, the result may be 
greater than one and an overflow will occur. Similarly, if two integers are 
multiplied, divided, subtracted or added, the likelihood of an overflow is 
apparent. 


48-Bit Precision (Double Precision) 

The 48-bit Add, Subtract, Multiply and Divide instructions enable operands to 
be processed. The Multiply and Divide instructions utilize the E register and 
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therefore are executed as trapped instructions if the applicable arithmetic 
option is not present in a system. Figure 5-5 in the Instruction Section illus¬ 
trates the operand formats in 48-bit precision Multiply and Divide instructions. 


FLOATING POINT ARITHMETIC 

As an alternative to fixed point operation a method involving a variable radix 
point, called floating point, is used. This significantly reduces the amount of 
bookkeeping required on the part of the programmer. 

By shifting the radix point and increasing or decreasing the value of the exponent, 
widely varying quantities which do not exceed the capacity of the machine may 
be handled. 

Floating point numbers within the computer are represented in a form similar 
to that used in scientific notation, that is, a coefficient or fraction multiplied 
by a number raised to a power. Since the computer uses only binary numbers, 
the numbers are multiplied by powers of two. 

F • 2® where: F = fraction 
E = exponent 

In floating point, different coefficients need not relate to the same power of the 
base as they do in fixed point format. Therefore, the construction of a floating 
point number includes not only the coefficient but also the exponent. 

NOTE 

Refer to Figure 5-6 in the Instruction Section for the operand format and 
bit functions for specific floating point instructions. 


Coefficient 

The coefficient consists of a 36-bit fraction in the 36 lower order positions of 
the floating point word. The coefficient is a normalized fraction; it is equal to 
or greater than 1/2 but less than 1. The highest order bit position (47) is 
occupied by the sign bit of the coefficient. If the sign bit is a "0", the co¬ 
efficient is positive; a "l" bit denotes a negative fraction (negative fractions are 
represented in one's complement notation). 


Exponent 


The floating point exponent is expressed as an 11-bit quantity with a value 
ranging from 0000 to 3111 q- I't is formed by adding a true positive exponent 
and a bias of 20008 or a true negative exponent and a bias of 17778. This re¬ 
sults in a range of biased exponents as shown on the following page. 
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True Positive 
Exponent 

Biased 

Exponent 

True Negative 
Exponent 

Biased 

Exponent 

+0 

2000 

-0 

200 

0* 

+1 

2001 

-1 

177 

6 

+2 

2002 

-2 

177 

5 

+1776 

3776 

-1776 

000 

1 

+1777g 

3777g 

-1777g 

000 

08 

47 46 

36 35 



00 


EXPONENT (INCLUDING BIAS) 
— SIGN BIT 


COEFFICIENT 


-Minus zero is sensed as positive zero by the computer and is therefore 
biased by 20000 rather than 17770. 

The exponent is biased so that floating point operands can be compared with 
each other in the normal fixed point mode. 

As an example, compare the unbiased exponents of +520 and +0.02g (Example 1). 
EXAMPLE 1 

Number = +52 g 

0 0 0 000 000 110 (36 bits) 

Coefficient Exponent Coefficient 

Sign 


Coefficient 

Sign 


Number = +0.02g 
1 1 111 111 Oil 

Exponent 


(36 bits) 
Coefficient 


In this case +0. 02 appears to be larger than +52 because of the larger exponent. 
If, however, both exponents are biased (Example 2), changing the sign of both 
exponents makes +52 greater than +0. 02. 


EXAMPLE 2 


Coefficient 

Sign 


Number = +52g 
1 0 000 000 110 
Exponent 

Number = +0. 02g 
0 1 111 111 Oil 

Exponent 


(36 bits) 
Coefficient 


Coefficient 

Sign 


(36 bits) 
Coefficient 














When bias is used with the exponent, floating point operation is more versatile 
since floating point operands can be compared with each other in the normal 
fixed point mode. 

All floating point operations involve the A, Q, and E registers, plus two con¬ 
secutive storage locations M and M + 1. The A and Q registers are treated as 
one 48-bit register. Indirect addressing and address modification are applicable 
to this whole group of instructions. 


Operand Formats 


The AQ register and the storage address contents have identical formats. 

In both cases the maximum possible shift is 64 (TTq) bit positions. Since the 
coefficient consists of only 36 bits at the start, any shift greater than 3 6 
positions will, of course, always result in an answer equal to the larger of the 
two original operands. 

(47) (46) (36) (35) (24) 

23 22 12 11 00 

(A) and (M) 


Sign of 11-bit operand Upper 12 bits of 

Coefficient exponent including operand coefficient 

bias 



23 00 

(Q)and(M + l) 


Lower 24 bits of opei’and coefficient 

Exponents 

The 3100, 3200, 3300 Computers use an 11-bit exponent that is biased by 2000g 
for floating point operations. The effective modulus of the exponent is + 1777g 
or + 1023jq. 


Exponent Equalization 

During floating point addition and subtraction, the exponents involved are 
equalized prior to the operation. 

• Addition - The coefficient of the algebraically smaller exponent is 
automatically shifted right in AQE until the exponents are equal. A 
maximum of 770 shifts may occur. 
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• Subtraction - If AQ contains the algebraically smaller exponent, the 
coefficient in AQ is shifted right in AQE until the exponents are equal. 

If (M) and (M + 1) have the smaller exponent, the complement of the 
coefficient of (M) and (M + 1) is shifted right in AQE until the exponents 
are equal or until a maximum of 77g shifts are performed. 


Rounding 

Rounding is an automatic floating point operation and is particularly necessary 
when floating point arithmetic operations yield coefficient answers in excess 
of 3 6 bits. 

Although standard floating point format requires only a 3 6-bit coefficient, 
portions of the E register are used for extended coefficients. Refer to in¬ 
dividual instruction descriptions for E register applications. 

Rounding modifies the coefficient result of a floating point operation by adding 
or subtracting a ”1" from the lowest bit position in Q without regard to the 
biased exponent. The coefficient of the answer in AQ passes through the adder 
with the rounding quantity before normalization. The conditions for rounding 
are classified according to arithmetic operation in Table B-2, 


TABLE B-2. ROUNDED CONDITIONS FOLLOWING ARITHMETIC OPERATION 


Arithmetic 

OPERATION 

Bit 23 of the 

A Register 

Bit 47 of the E Register 
or 

(Ratio of Residue/Divisor 
for Divide Only) 

Applicable 

Rounding 

ADD 

or 

SUBTRACT 


0 

No 

0* 

1 

Add "1" 

1 'fi 

0 

Subtract "1" 

1 

1 

No 

Comments: Rounding occurs as a result of inequality between 
the sign bits of AQ and E. 

MULTIPLY 

0 

0 

No 

0 

1 

Add ”1" 

1 

0 

Subtract "I” 

1 

1 

No 

Comments: A floating point multiplication yields a 76 bit 

coefficient. Comparison between the sign bits of 

AQ and E indicates that the lower 3 6 bits are equal 
to or greater than 1/2 of the lowest order bit in AQ. 

DIVIDE 

0 

> 112 (absolute) 

Add "I” 

0 

< 1/2 (absolute) 

No 

1 

>1/2 (absolute) 

Subtract "1" 

1 

<1/2 (absolute) 

No 

Comments: Rounding occurs if the answer resulting from the 

final residue division is equal to or greater than 1/2. 


=:=Condition of bit 23 of the A register immediately after equalization. (Refer 
to Exponent Equalization on proceeding page). 
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Normalizing 


Normalizing brings the above answer back to a fraction with a value between 
one-half and one with the binary point to the left of the 36th bit of the coefficient 
In other words, the final normalized coefficient in AQ will range in value from 
236 to 237-1 including sign. Arithmetic control normalizes the answer by right 
or left shifting the coefficient the necessary number of places and adjusting the 
exponent. It does not shift the residue that is in E. 


Faults 

Three conditions are considered faults during the execution of floating point 
instructions: 

• Exponent overflow (> + I 7773 ) 

• Exponent underflow ( < — 1777g) 

• Division by zero, by too small a number, or by a number that is not 
in floating point format 

These faults have several things in common: 

• They can be sensed by the INS (77. 3) instruction 

• Sensing automatically clears them 

• The program should sense for these faults only after the floating point 
instructions have had sufficient time to go to completion 

• They may be used to cause an interrupt 


FIXED POINT/FLOATING POINT CONVERSIONS 
Fixed Point To Floating Point 


• Express the number in binary. 

• Normalize the number. A normalized number has the most significant 

1 positioned immediately to the right of the binary point and is expressed 
in the range 1 / 2 < k <1. 

• Inspect the sign of the true exponent. If the sign is positive add 2000g 
(bias) to the true exponent of the normalized number. If the sign is 
negative, add the bias 1777g to the true exponent of the normalized 
number. In either case, the resulting exponent is the biased exponent. 

• Assemble the number in floating point. 

• Inspect the sign of the coefficient. If negative, complement the 
assembled floating point number to obtain the true floating point re¬ 
presentation of the number. If the sign of the coefficient is positive, 
the assembled floating point number is the true representation. 
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EXAMPLE 1 Convert +4. 0 to floating point 

• The number is expressed in octal. 

• Normalize 4. 0 = 4. 0 x 8 *^ = 0, 100x2^ 

• Since the sign of the true exponent is positive, add 2 OOO 3 
(bias) to the true exponent. Biased exponent = 2000 + 3. 

• Assemble number in floating point format. 

Coefficient = 400 000 000 OOO 3 

Biased Exponent = 20083 

Assembled word = 2003 400 000 000 OOOg 

• Since the sign of the coefficient is positive, the floating point 
representation of +4. 0 is as shown. If, however, the sign of 
the coefficient were negative, it would be necessary to com¬ 
plement the entire floating point word. 

EXAMPLE 2 Convert -4. 0 to floating point 

• The number is expressed in octal. 

• Normalize -4. 0 = -4. 0x8® = -0. 100 x 2^ 

• Since the sign of the true exponent is positive, add 2 OOO 3 
(bias) to the true exponent. Biased exponent = 2000 + 3. 

• Assemble number in floating point format. 

Coefficient = 400 000 000 OOOg 

Biased Exponent = 200 83 

Assembled word = 2003 400 000 000 OOO 3 

• Since the sign of the coefficient is negative, the assembled 

floating point word must be complemented. Therefore, the 

true floating point representation for 

-4.0 = 5774 377 777 777 777„. 

o 

EXAMPLE 3 Convert 0. 5^0 to floating point 

• Convert to octal 0 . 5j^o ~ ®- ^8 

• Normalize 0. 4 = 0. 4 x 8® = 0. 100 x 20 

• Since the sign of the true exponent is positive, add 2 OOO 3 
(bias) to the true exponent. Biased exponent = 2000 + 0. 

• Assemble number in floating point format. 

Coefficient = 400 000 000 OOO 3 

Biased Exponent = 2 OOO 3 

Assembled word = 2000 400 000 000 OOO 3 

• Since the sign of the coefficient is positive, the floating point 
representation of +0. is as shown. If, however, the sign 
of the coefficient were negative, it would be necessary to 
complement the entire floating point word. This example is a 
special case of floating point since the exponent of the nor¬ 
malized number is_0 and could be represented as -0. The 
exponent would then be biased by 17773 instead of 20 OO 3 because 
of the negative exponent. The 3100 and 3200, however, recognize 
-0 as +0 and bias the exponent by 20 OO 3 . 
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EXAMPLE 4 Convert O .043 to floating point 

• The number is expressed in octal. 

. Normalize 0. 04 = 0. 04 x 8® = 0. 4 x 8"^ = 0. 100 x 2"^. 

• Since the sign of the true exponent is negative, add 1111^ 
(bias) to the true exponent. Biased exponent = 1777g + 

(-3) = 1774g 

• Assemble number in floating point format. 

Coefficient = 400 000 000 OOOg 

Biased Exponent = 17748 

Assembled word = 1774 400 000 000 OOOg 

• Since the sign of the coefficient is positive, the floating 
point representation of 0. 04g is as shown. If, however, the 
sign of the coefficient were negative, it would be necessary 
to complement the entire floating point word. 


Floating Point to Fixed Point Format 

• If the floating point number is negative, complement the entire floating 
point word and record the fact that the quantity is negative. The ex¬ 
ponent is now in a true biased form. 

• If the biased exponent is equal to or greater than 2000g, subtract 2000g 
to obtain the true exponent; if less than 20008 , subtract 17778 to obtain 
true exponent. 

• Separate the coefficient and exponent. If the true exponent is negative, 
the binary point should be moved to the left the number of bit positions 
indicated by the true exponent. If the true exponent is positive, the 
binary point should be moved to the right the number of bit positions 
indicated by the true exponent. 

• The coefficient has now been converted to fixed binary. The sign of the 
coefficient will be negative if the floating point number was complemented 
in step one. (The sign bit must be extended if the quantity is placed in a 
register. ) 

• Represent the fixed binary number in fixed octal notation. 

EXAMPLE 1 Convert floating point number 2003 400 000 000 OOOg 
to Rxed octal 

• The floating point number is positive and remains uncomplemented. 

• The biased exponent >2000g; therefore, subtract 2000g from the 
biased exponent to obtain the true exponent of the number. 

2003 - 2000 = +3. 

• Coefficient = 400 000 000 OOOg = . IOO 2 . Move binary point 
to the right three places. Coefficient = 100. O 2 . 

• The sign of the coefficient is positive because the floating 
point number was not complemented in step one. 

• Represent in fixed octal notation. 

100. 0 X 2 O = 4. 0 X 8 ^. 
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EXAMPLE 2 Convert floating point number 

5774 377 777 777 777^ to fixed octal 

O 

• The sign of the coefficient is negative; therefore, complement 
the floating point number. 

Complement = 2003 400 000 000 OOOg 

• The biased exponent (in complemented form) >20008; there¬ 
fore, subtract 2000g from the biased exponent to obtain the 
true exponent of the number 2003 - 2000 = +3. 

• Coefficient = 4000 000 000 OOOg = 0. lOOg. Move binary 
point to the right three places. Coefficient = 100. Og. 

• The sign of the coefficient will be negative because the floating 
point number was originally complemented. 

• Convert to fixed octal. -100. O 2 = 4. Og. 

EXAMPLE 3 Convert floating point number 

1774 400 000 000 OOOg to fixed octal 

• The floating point number is positive and remains uncom¬ 
plemented. 

• The biased exponent <2000g; therefore, subtract 1777g 
from the biased exponent to obtain the true exponent of the 
number. 1774g - 1777g = -3. 

• Coefficient = 400 000 000 OOOg = . IOO 2 . Move binary 
point to the left three places. Coefficient = . OOOIOO 2 . 

• The sign of the coefficient is positive because the floating 
point number was not complemented in step one. 

• Represent in fixed octal notation. 

.OOOIOO 2 = .04g. 
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APPENDIX C 

PROGRAMMING REFERENCE TABLES AND 
CONVERSION INFORMATION 



TABLE OF POWERS OF TWO 
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n 

2 " 

























1 

0 

10 

























2 

1 

0 5 

























4 

2 

0.25 

























8 

3 

0.125 

























16 

4 

0062 

5 
























32 

5 

0031 

25 
























64 

6 

0.015 

625 
























128 

7 

0.007 

812 

5 























256 

8 

0.003 

906 

25 























512 

9 

0.001 

953 

125 






















1 

024 

10 

0.000 

976 

562 

5 





















2 

048 

11 

0 000 

488 

281 

25 





















4 

096 

12 

0.000 

244 

140 

625 





















8 

192 

13 

0.000 

122 

070 

312 

5 




















16 

384 

14 

0000 

061 

035 

156 

25 




















32 

768 

15 

0000 

030 

517 

578 

125 




















65 

536 

16 

0.000 

015 

258 

789 

062 

5 



















131 

072 

17 

0.000 

007 

629 

394 

531 

25 



















262 

144 

18 

0000 

003 

814 

697 

265 

625 



















524 

288 

19 

0.000 

001 

907 

348 

632 

812 

5 

















1 

048 

576 

20 

0000 

000 

953 

674 

316 

406 

25 

















2 

097 

152 

21 

0.000 

000 

476 

837 

158 

203 

125 

















4 

194 

304 

22 

0.000 

000 

238 

418 

579 

101 

562 

5 
















8 

388 

608 

23 

0.000 

000 

119 

209 

289 

550 

781 

25 
















16 

777 

216 

24 

0.000 

000 

059 

604 

644 

775 

390 

625 
















33 

554 

432 

25 

0.000 

000 

029 

802 

322 

387 

695 

312 

5 















67 

108 

864 

26 

0000 

000 

014 

901 

161 

193 

847 

656 

25 















134 

217 

728 

27 

0000 

000 

007 

450 

580 

596 

923 

828 

125 















268 

435 

456 

28 

0.000 

000 

003 

725 

290 

298 

461 

914 

062 

5 














536 

870 

912 

29 

0000 

000 

001 

862 

645 

149 

230 

957 

031 

25 













1 

073 

741 

824 

30 

0.000 

000 

000 

931 

322 

574 

615 

478 

515 

625 













2 

147 

483 

648 

31 

0.000 

000 

000 

465 

661 

287 

307 

739 

257 

812 

5 












4 

294 

967 

296 

32 

0.000 

000 

000 

232 

830 

643 

653 

869 

628 

906 

25 












8 

589 

934 

592 

33 

0000 

000 

000 

116 

415 

321 

826 

934 

814 

453 ' 

125 












17 

179 

869 

184 

34 

0000 

000 

000 

058 

207 

660 

913 

467 

407 

226 

562 

5 











34 

359 

738 

368 

35 

0.000 

000 

000 

029 

103 

830 

456 

733 

703 

613 

281 

25 











68 

719 

476 

736 

36 

0.000 

000 

000 

014 

551 

915 

228 

366 

851 

806 

640 

625 











137 

438 

953 

472 

37 

0000 

000 

000 

007 

275 

957 

614 

183 

425 

903 

320 

312 

5 










274 

877 

906 

944 

38 

0.000 

000 

000 

003 

637 

978 

807 

091 

712 

951 

660 

156 

25 










549 

755 

813 

888 

39 

0.000 

000 

000 

001 

818 

989 

403 

545 

856 

475 

830 

078 

125 









1 

099 

511 

627 

776 

40 

0.000 

000 

000 

000 

909 

494 

701 

772 

928 

237 

915 

039 

062 

5 








2 

199 

023 

255 

552 

41 

0.000 

000 

000 

000 

454 

747 

350 

886 

464 

118 

957 

519 

531 

25 








4 

398 

046 

511 

104 

42 

0000 

000 

000 

000 

227 

373 

675 

443 

232 

059 

478 

759 

765 

625 








8 

796 

093 

022 

208 

43 

0.000 

000 

000 

000 

113 

686 

837 

721 

616 

029 

739 

379 

882 

812 

5 







17 

592 

186 

044 

416 

44 

0.000 

000 

000 

000 

056 

843 

418 

860 

808 

014 

869 

689 

941 

406 

25 







35 

184 

372 

088 

832 

45 

0.000 

000 

000 

000 

028 

421 

709 

430 

404 

007 

434 

844 

970 

703 

125 







70 

368 

744 

177 

664 

46 

0000 

000 

000 

000 

014 

210 

854 

715 

202 

003 

717 

422 

485 

351 

562 

5 






140 

737 

488 

355 

328 

47 

0.000 

000 

000 

000 

007 

105 

427 

357 

601 

001 

858 

711 

242 

675 

781 

25 






281 

474 

976 

710 

656 

48 

0000 

000 

000 

000 

003 

552 

713 

678 

800 

500 

929 

355 

621 

337 

890 

625 






562 

949 

953 

421 

312 

49 

0.000 

000 

000 

000 

001 

776 

356 

839 

400 

250 

464 

677 

810 

668 

945 

312 

5 




1 

125 

899 

906 

842 

624 

50 

0.000 

000 

000 

000 

000 

888 

178 

419 

700 

125 

232 

338 

905 

334 

472 

656 

25 




2 

251 

799 

813 

685 

248 

51 

0.000 

000 

000 

000 

000 

444 

089 

209 

850 

062 

616 

169 

452 

667 

236 

328 

125 




4 

503 

599 

627 

370 

496 

52 

0.000 

000 

000 

000 

000 

222 

044 

604 

925 

031 

308 

084 

726 

333 

618 

164 

062 

5 



9 

007 

199 

254 

740 

992 

53 

0.000 

000 

000 

000 

000 

111 

022 

302 

462 

515 

654 

042 

363 

166 

809 

082 

031 

25 



18 

014 

398 

509 

481 

984 

54 

0.000 

000 

000 

000 

000 

055 

511 

151 

231 

257 

827 

021 

181 

583 

404 

541 

015 

625 



36 

028 

797 

018 

963 

968 

55 

0.000 

000 

000 

000 

000 

027 

755 

575 

615 

628 

913 

510 

590 

791 

702 

270 

507 

812 

5 


72 

057 

594 

037 

927 

936 

56 

0.000 

000 

000 

000 

000 

013 

877 

787 

807 

814 

456 

755 

295 

395 

851 

135 

253 

906 

25 


144 

115 

188 

075 

855 

872 

57 

0.000 

000 

000 

000 

000 

006 

938 

893 

903 

907 

228 

377 

647 

697 

925 

567 

626 

953 

125 


288 

230 

376 

151 

711 

744 

58 

0.000 

000 

000 

000 

000 

003 

469 

446 

951 

953 

614 

188 

823 

848 

962 

783 

813 

476 

562 

5 

576 

460 

752 

303 

423 

488 

59 

0000 

000 

000 

000 

000 

001 

734 

723 

475 

976 

807 

094 

411 

924 

481 

391 

906 

738 

281 

25 

1 152 

921 

504 

606 

846 

976 

60 

0000 

000 

000 

000 

000 

000 

867 

361 

737 

988 

403 

547 

205 

962 

240 

695 

953 

369 

140 

625 
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DECIMAL/BINARY POSITION TABLE 


Largest Decimal 
integer 

Decimal 

Digits 

Req'd* 

Number 

of 

Binary 

Digits 

Largest Decimal Fraction 






1 

3 


1 

2 

.5 

,75 























7 


3 

,875 























15 


4 

.937 

5 






















31 



.968 

75 






















63 



.984 

375 






















127 

2 


.992 

187 

5 





















255 


8 

.996 

093 

75 





















511 


9 

.998 

046 

875 




















1 

023 

3 

10 

.999 

023 

437 5 




















2 

047 


11 

.999 

511 

718 75 




















4 

095 


12 

.999 

755 859 375 




















8 

191 


13 

.999 

877 

929 687 5 




















16 

383 

4 

14 

.999 

938 

964 843 75 
















■1 

■ 

■ 

■ 




15 

.999 

969 482 421 875 
















■ 

■ 

■ 

■ 




16 

.999 

984 

741 210 937 

5 
















■ 

■ 

■ 



5 

17 

.999 

992 

370 605 468 

75 



















262 

143 




996 

185 302 734 375 



















524 

287 




998 092 651 367 

187 

5 

















1 

048 

575 

6 



999 

046 325 683 

593 

75 

















2 

097 

1b1 


21 

.999 

999 

523 162 841 

796 

875 

















4 

194 

303 


22 

.999 

999 

761 581 420 

898 

437 

5 
















8 

388 607 


23 

.999 

999 

880 790 710 

449 

218 

75 
















16 

777 

215 


24 

.999 

999 

940 395 355 

244 

609 

375 
















33 

554 431 


25 


999 

970 197 677 

6l2 

304 

68/ 

5 















67 

108 

863 


26 

.999 

999 

985 QS8 B38 

806 

152 

343 

75 















134 217 

727 

8 

27 

.999 

999 

992 549 419 403 

076 

171 

875 















268 435 

455 


28 

.999 

999 

996 274 709 

701 

536 

085 937 

5 














536 

870 

911 


29 

.999 

999 

998 137 354 850 

769 

042 

968 

75 













1 

073 

741 

823 

9 

30 

.999 

999 

999 068 677 

425 

384 

521 

484 

375 













2 

14/ 

483 647 



■ ::: 

999 

999 534 338 

712 

692 

260 

742 

187 

5 












4 

294 

967 

295 



HTT! 

999 

999 767 169 

356 

346 

130 

371 

093 

75 












8 

589 

934 

591 



HTT^ 

999 

999 883 584 678 

173 

065 

185 

546 875 












17 

179 

869 

183 

10 


HTT! 

999 

999 941 792 

339 

086 

532 

592 

773 437 

5 











34 

359 

738 

367 



.999 

999 

999 970 896 

169 

543 

266 

296 386 718 

75 











68 

719 476 

735 



.999 

999 

999 985 448 

034 771 

633 

148 

193 

359 

375 











137 

438 953 471 



.999 

999 

999 992 724 

042 

385 

816 

574 

096 

679 

687 

5 










274 877 

906 943 


38 

.999 

999 

999 996 362 

021 

192 

908 

287 

048 

339 

843 

75 










549 

755 

813 

887 


39 

.999 999 

999 998 181 

010 

596 

454 

143 

524 

169 

921 

875 









1 

099 

511 

627 

775 

12 

40 

.999 

999 

999 999 090 

SOS 

298 

227 

071 

762 

084 

960 

937 

5 








■ 

199 

023 

255 

551 




999 

999 999 545 

252 

649 

113 

535 

881 

042 

480 

468 

75 








■ 

398 

046 

511 

103 




999 

999 999 772 

626 

324 

556 

767 

940 

521 

240 

234 

375 








H 

796 

093 

022 

207 




999 

999 999 886 

313 

162 

278 

383 

970 

260 

620 

117 

187 

5 







n 

592 

186 

044 

415 

13 



999 

999 999 943 

156 

581 

139 

191 

985 

130 

310 

058 

593 

75 







35 

184 

372 

imtii 

831 



.999 999 

999 999 971 

578 

290 

569 

595 

992 565 

155 

029 

296 

875 







■a 

368 

744 

177 

663 




999 

999 999 985 

789 

145 

284 

797 

996 

282 

577 

514 648 

437 

5 






140 

737 

488 

355 

327 




999 

999 999 992 

894 

572 

642 

398 

998 

141 

288 

757 

324 

218 

75 














999 

999 993 996 

447 

286 

321 

199 

499 

070 

644 

378 

662 

109 

375 














999 

999 999 998 

223 

643 

160 

599 

749 

535 

322 

189 

331 

054 

687 

5 













999 

999 999 999 

111 

821 

580 

299 

874 

767 

661 

094 

665 

527 

343 

75 





251 

799 

813 

685 

247 




999 

999 999 999 

555 

910 

790 

149 

937 

383 

830 

547 

332 

763 

671 

875 





503 

599 

627 

370 

495 




999 

999 999 999 

777 

955 

395 

074 

968 

691 

915 

273 

666 

381 

835 

937 

5 

H 

H 

HI 

007 

199 

254 

740 

991 




999 

993 999 999 

888 

977 

697 

537 

484 

345 

957 

636 

833 

190 

917 

968 

75 

H 

H 


014 

398 

909 

481 

983 




999 

999 993 999 

944 

488 

848 

768 

742 

172 

978 

818 

416 

595 

458 

984 

375 

■ 

■ 




liHJ 





HliPPI 



Eng 












irn 

Bi 

■1 

HI 








Will 

^1 










Bifi 

ny 




19 

H 

MB 



liHl 





HU 



tBcl 








Biyl 






H 

288 

230 

376 

151 

711 

743 


98 

.999 

999 

999 999 999 

996 

530 

553 

048 

046 

385 

811 

176 

151 

037 

216 

186 

523 

437 

5 

576 

460 

752 

303 

423 

487 


59 

.999 

999 

999 999 999 

998 

266 

276 

524 

023 

192 

905 

588 

075 

518 

608 

093 

261 

718 

75 

1 152 

921 

904 

606 

846 

975 

18 

60 

.999 

999 

999 999 999 

999 

132 

638 

262 

on 

596 

452 

794 

037 

759 

304 04d 

630 

859 

375 


*Larger numbers within a digit group should be checked for exact number of decimal digits required. 


Examples of use: 

1. Q. What is the largest decimal value that can be expressed by 36 binary digits? 
A. 68,719,476,735. 

2. Q. How many decimal digits will be required to express a 22-bit number? 

A. 7 decimal digits. 
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CONSTANTS 


TT 

= 

3.14159 

26535 

89793 

23846 

26433 

83279 50 


= 

1.732 050 807 

569 




v/TO 

= 

3.162 277 660 

1683 




e 

= 

2.71828 

18284 

59045 

23536 



In 2 

= 

0.69314 

71805 

599453 




In 10 

= 

2.30258 

50929 

94045 

68402 



logio 2 

= 

0.30102 

99956 

63981 




logic e 

= 

0.43429 

44819 

03251 

82765 



logic logic e 

= 

9.63778 

43113 

00537 

-10 



logic TT 

= 

0.49714 

98726 

94133 

85435 



1 degree 

= 

0.01745 

32925 

11943 

radians 



1 radian 

= 

57.29577 

95131 

degrees 




logic(5) 

= 

0.69897 

00043 

36019 




7! 

= 

5040 






8! 

= 

40320 






9! 

= 

362.880 






10! 


3.628.800 






11 ! 

= 

39.916.800 





12! 

= 

479.001.600 





13! 

= 

6.227.020.800 





14! 

= 

87.178.291.200 





15! 

= 

1.307.674.368.000 





16! 

= 

20.922.7P9.888.000 




TT 


0.01745 

I 32925 

19943 

29576 

92369 

07684 9 

180 









= 

2.4674 

01100 

27233 

96 




= 

3.8757 

84585 

03747 

74 





6.0880 

68189 

62515 

20 




= 

9.5631 

15149 

54004 

49 



ff)- 

= 

15.0217 

06149 

61413 

07 




= 

23.5960 

40842 

00618 

62 




= 

37.0645 

72481 

52567 

57 



fi)’ 

= 

58.2208 

97135 

63712 

59 



(f)'" 

= 

91.4531 

71363 

36231 

53 



ff)' 

= 

143.6543 

05651 

31374 

95 




= 

225.6516 

55645 

350 




(i)’’ 

= 

354.4527 

91822 

91051 

47 




= 

556.7731 

43417 

624 
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CONSTANTS (Continued) 


ir^ 

= 

9.86960 

44010 

2ir2 

= 

19.73920 

88021 

3ir2 


29.60881 

32032 

47r^ 


39.47841 

76043 

5ir^ 

= 

49.34802 

20054 

6ir^ 

= 

59.21762 

64065 

77r2 

= 

69.08723 

08076 

87r2 

= 

78.95683 

52087 


s=: 

88.82643 

96098 


y/2 = 1.414 213 

^ + y/2 = 2.414 213 

(1 + = 5.828 427 

(1 + v'2)'' = 33.970 562 

(1 + = 197.994 949 

(1 + \/2)8 = 1153.999 133 

(1 + \/2)'° = 6725.999 851 

(1 + = 39201.999 974 

(1 + = 228485.999 995 

(1 + V2)'6 = 1331713.999 999 

(1 + v/2)'8 = 7761797.999 999 


Sin .5 = 0.47942 55386 

Cos .5 = 0.87758 25618 

Tan .5 = 0.54630 24898 

Sin 1 = 0.84147 09848 

Cos 1 = 0.54030 23058 

Tan 1 = 1.55740 77246 

Sin 1 5 = 0.99749 49866 

Cos 1.5 = 0.07073 72016 

Tan 1.5 = 14.10141 99471 


89358 61883 43909 9988 
78717 23766 87819 9976 
68075 85680 31729 9964 
57434 47533 75639 9952 
46793 09417 19549 9940 
36151 71300 63459 9928 
25510 33184 07369 9916 
14868 95067 51279 9904 
04227 56950 95189 9892 


562 373 095 048 801 688 

562 373 095 048 801 688 

124 746 18 

748 477 08 

366 116 30 

448 220 72 

323 208 02 

491 027 40 

622 956 38 

246 711 

884 751 


04203 

90373 

43790 

07896 

68140 

5490 

04054 

67708 

707 
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OCTAL-DECIMAL INTEGER CONVERSION TABLE 




0 

1 

2 

3 

4 

0400 

0256 

0257 

0258 

0259 

0260 

0410 

0264 

0265 

0266 

0267 

0268 

0420 

0272 

0273 

0274 

0275 

0276 

0430 

0280 

0281 

0282 

0283 

0284 

0440 

0283 

0289 

0290 

0291 

0292 

0450 

0296 

0297 

0298 

0299 

0300 

0460 

0304 

0305 

0306 

0307 

0308 

0470 

0312 

0313 

0314 

0315 

0316 

0500 

0320 

0321 

0322 

0323 

0324 

0510 

0328 

0329 

0330 

0331 

0332 

0520 

0336 

0337 

0338 

0339 

0340 

0530 

0344 

0345 

0346 

0347 

0348 

0540 

0352 

0353 

0354 

0355 

0356 

0550 

0360 

0361 

0362 

0363 

0364 

0560 

0368 

0369 

0370 

0371 

0372 

0570 

0376 

0377 

0378 

0379 

0380 

0600 

0384 

0385 

0386 

0387 

0388 

0610 

0392 

0393 

0394 

0395 

0396 

0620 

0400 

0401 

0402 

0403 

0404 

0630 

0408 

0409 

0410 

0411 

0412 

0640 

0416 

0417 

0418 

0419 

0420 

0650 

0424 

0425 

0426 

0427 

0428 

0660 

0432 

0433 

0434 

0435 

0436 

0670 

0440 

0441 

0442 

0443 

0444 

0700 

0448 

0449 

0450 

0451 

0452 

0710 

0456 

0457 

0456 

0459 

0460 

0720 

0464 

0465 

0466 

0467 

0468 

0730 

0472 

0473 

0474 

0475 

0476 

0740 

0480 

0481 

0482 

0483 

0484 

0750 

0488 

0489 

0490 

0491 

0492 

0760 

0496 

0497 

0498 

0499 

0500 

0770 

0504 

0505 

0506 

0507 

0508 


5 

6 

7 



0261 

0262 

0263 

0000 

0000 

0269 

0270 

0271 



0277 

0278 

0279 

0777 

0511 

0285 

0293 

0286 

0294 

0287 

0295 

(Octal) 

(Decimal) 

0301 

0302 

0303 



0309 

0310 

0311 



0317 

0318 

0319 

Octal 

Decimal 




10000 - 

4096 

0325 

0326 

0327 

20000 - 

8192 

0333 

0334 

0335 

30000 - 

12288 

0341 

0342 

0343 

0349 

0350 

0351 

40000 

16384 

0357 

0358 

0359 

50000 - 

20480 

0365 

0366 

0367 

60000 - 

24576 

0373 

0374 

0375 

70000 - 

28672 

0381 

0382 

0383 



0389 

0390 

0391 



0397 

0398 

0399 



0405 

0406 

0407 



0413 

0414 

0415 



0421 

0422 

0423 



0429 

0430 

0431 



0437 

0438 

0439 



0445 

0446 

0447 



0453 

0454 

0455 



0461 

0462 

0463 



0469 

0470 

0471 



0477 

0478 

0479 



0485 

0486 

0487 



0493 

0494 

0495 



0501 

0502 

0503 



0509 

0510 

0511 






1000 

to 

1777 

{Octal) 


0B12 

to 

1023 

(Decimal) 
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OCTAL-DECIMAL INTEGER CONVERSION TABLE (Cont'd) 


2000 





















0 

1 

2 

3 

4 

5 

6 

7 


0 

1 

2 

3 

4 

5 

6 

7 


t024 

2000 

1024 

1025 

1026 

1027 

1028 

1029 

1030 

1031 


2400 

1280 

1281 

1282 

1283 

1284 

1285 

1286 

1287 



to 

2010 

1032 

1033 

1034 

1035 

1036 

1037 

1038 

1039 


2410 

1288 

1289 

1290 

1291 

1292 

1293 

1294 

1295 


2777 

1535 

2020 

1040 

1041 

1042 

1043 

1044 

1045 

1046 

1047 


2420 

1296 

1297 

1298 

1299 

1300 

1301 

1302 

1303 


(Octal) 

(Decimal) 

2030 

1048 

1049 

1050 

1051 

1052 

1053 

1054 

1055 


2430 

1304 

1305 

1306 

1307 

1308 

1309 

1310 

1311 




2040 

1056 

1057 

1058 

1059 

1060 

1061 

1062 

1063 


2440 

1312 

1313 

1314 

1315 

1316 

1317 

1318 

1319 




2050 

1064 

1065 

1066 

1067 

1068 

1069 

1070 

1071 


2450 

1320 

1321 

1322 

1323 

1324 

1325 

1326 

1327 




2060 

1072 

1073 

1074 

1075 

1076 

1077 

1078 

1079 


2460 

1328 

1329 

1330 

1331 

1332 

1333 

1334 

1335 


ICOOO ■ 

4096 

2070 

1080 

1081 

1082 

1083 

1084 

1085 

1086 

1087 


2470 

1336 

1337 

1338 

1339 

1340 

1341 

1342 

1343 


20QO0 - 

8192 

2100 

1088 

1089 

1090 

1091 

1092 

1093 

1094 

1095 


2500 

1344 

1345 

1346 

1347 

1348 

1349 

1350 

1351 


30000 ■ 

12288 

2110 

1096 

1097 

1098 

1099 

1100 

1101 

1102 

1103 


2510 

1352 

1353 

1354 

1355 

1356 

1357 

1358 

1359 


40000 - 

16384 

2120 

1104 

1105 

1106 

1107 

1108 

1109 

1110 

nil 


2520 

1360 

1361 

1362 

1363 

1364 

1365 

1366 

1367 


50000 ■ 

20480 

2130 

1112 

1113 

1114 

1115 

1116 

1117 

1118 

1119 


2530 

1368 

1369 

1370 

1371 

1372 

1373 

1374 

1375 


60000 ■ 

24576 

2140 

1120 

1121 

1122 

1123 

1124 

1125 

1126 

1127 


2540 

1376 

1377 

1378 

1379 

1380 

1381 

1382 

1383 




2150 

1128 

1129 

1130 

1131 

1132 

1133 

1134 

1135 


2550 

1384 

1385 

1386 

1387 

1388 

1389 

1390 

1391 




2160 

1136 

1137 

1138 

1139 

1140 

1141 

1142 

1143 


2560 

1392 

1393 

1394 

1395 

1396 

1397 

1398 

1399 




2170 

1144 

1145 

1146 

1147 

1148 

1149 

1150 

1151 


2570 

1400 

1401 

1402 

1403 

1404 

1405 

1406 

1407 




2200 

1152 

1153 

1154 

1155 

1156 

1157 

1158 

1159 


2600 

1408 

1409 

1410 

1411 

1412 

1413 

1414 

1415 




2210 

1160 

1161 

1162 

1163 

1164 

1165 

1166 

1167 


2610 

1416 

1417 

1418 

1419 

1420 

1421 

1422 

1423 




2220 

1168 

1169 

1170 

1171 

1172 

1173 

1174 

1175 


2620 

1424 

1425 

1426 

1427 

1428 

1429 

1430 

J<31 




2230 

1176 

1177 

1178 

1179 

1180 

1181 

1182 

1183 


2630 

1432 

1433 

1434 

1435 

1436 

1437 

1438 

1439 




2240 

1184 

1185 

1186 

1187 

1188 

1189 

1190 

1191 


2640 

1440 

1441 

1442 

1443 

1444 

1445 

1446 

1447 




2250 

1192 

1193 

1194 

1195 

1196 

1197 

1198 

1199 


2650 

1448 

1449 

1450 

1451 

1452 

1453 

1454 

1455 




2260 

1200 

1201 

1202 

1203 

1204 

1205 

1206 

1207 


2660 

1456 

1457 

1458 

1459 

1460 

1461 

1462 

1463 




2270 

1208 

1209 

1210 

1211 

1212 

1213 

1214 

1215 


2670 

1464 

1465 

1466 

1467 

1468 

1469 

1470 

1471 




2300 

1216 

1217 

1218 

1219 

1220 

1221 

1222 

1223 


2700 

1472 

1473 

1474 

1475 

1476 

1477 

1478 

1479 




2310 

1224 

1225 

1226 

1227 

1228 

1229 

1230 

1231 


2710 

1480 

1481 

1482 

1483 

1484 

1485 

1486 

1487 




2320 

1232 

1233 

1234 

1235 

1236 

1237 

1238 

1239 


2720 

1488 

1489 

1490 

1491 

1492 

1493 

1494 

1495 




2330 

1240 

1241 

1242 

1243 

1244 

1245 

1246 

1247 


2730 

1496 

1497 

1498 

1499 

1500 

1501 

1502 

1503 




2340 

1248 

1249 

1250 

1251 

1252 

1253 

1254 

1255 


2740 

1504 

1505 

1506 

1507 

1508 

1519 

1510 

1511 




2350 

1256 

1257 

1258 

1259 

1260 

1261 

1262 

1263 


2750 

1512 

1513 

1514 

1515 

1516 

1517 

1518 

1519 




2360 

1264 

1265 

1266 

1267 

1268 

1269 

1270 

1271 


2760 

1520 

1521 

1522 

1523 

1524 

1525 

1526 

1527 




2370 

1272 

1273 

1274 

1275 

1276 

1277 

1278 

1279 


2770 

1528 

1529 

1530 

1531 

1532 

1533 

1534 

1535 

























0 

1 

2 

3 

4 

5 

6 

7 


0 

1 

2 

3 

4 

5 

6 

7 


3000 

1536 

3000 

1536 

1537 

1538 

1539 

1540 

1541 

1542 

1543 


3400 

1792 

1793 

1794 

1795 

1796 

179? 

1798 

1799 


to 

to 

3010 

1544 

1545 

1546 

1547 

1548 

1549 

1550 

1551 


3410 

1800 

1801 

1802 

1803 

1804 

1805 

1806 

1807 


3777 

2047 

3020 

1552 

1553 

1554 

1555 

1556 

1557 

1558 

1559 


3420 

1808 

1809 

1810 

1811 

1812 

1813 

1814 

1815 


(Octal) 

(Decimal) 

3030 

1560 

1561 

1562 

1563 

1564 

1565 

1566 

1567 


3430 

1816 

1817 

1818 

1819 

1820 

1821 

1822 

1823 




3040 

1566 

1569 

1570 

1571 

1572 

1573 

1574 

1575 


3440 

1824 

1825 

1826 

1827 

1828 

1829 

1830 

1831 




3050 

1576 

1577 

1578 

1579 

1580 

1581 

1582 

1583 


3450 

1832 

1833 

1834 

1835 

1836 

1837 

1838 

1839 




3060 

1584 

1585 

1536 

1587 

1588 

1589 

1590 

1591 


3460 

1840 

1841 

1842 

1843 

1844 

1845 

1846 

1847 




3070 

1592 

1593 

1594 

1595 

1598 

1597 

1598 

1599 


3470 

T848 

1849 

1850 

1851 

1852 

1853 

1854 

1855 




3100 

1600 

1601 

1602 

1603 

1604 

1605 

1606 

1607 


3500 

1856 

1857 

1858 

1859 

1860 

1861 

1862 

1863 




3110 

1608 

1609 

1610 

1611 

1612 

1613 

1614 

1615 


3510 

1864 

1865 

1866 

1867 

1868 

1869 

1870 

1871 




3120 

1616 

1617 

1618 

1619 

1620 

1621 

1622 

1623 


3520 

1872 

1873 

1874 

1875 

1876 

1877 

1878 

1879 




3130 

1624 

1625 

1626 

1627 

1628 

1629 

1630 

1631 


3530 

1880 

1881 

1882 

1883 

1884 

1885 

1886 

1887 




3140 

1632 

1633 

1634 

1635 

1636 

1637 

1638 

1639 


3540 

1888 

1889 

1890 

1891 

1892 

1893 

1894 

1895 




3150 

1640 

1641 

1642 

1643 

1644 

1645 

1646 

1647 


3550 

1896 

1897 

1898 

1899 

1900 

1901 

1902 

1903 




3160 

1648 

1649 

1650 

1651 

1652 

1653 

1654 

1655 


3560 

1904 

1905 

1906 

1907 

1908 

1909 

1910 

1911 




3170 

1656 

1657 

1658 

1659 

1660 

1661 

1662 

1663 


3570 

1912 

1913 

1914 

1915 

1316 

1917 

1918 

1919 




3200 

1664 

1665 

1666 

1667 

1668 

1669 

1670 

1671 


3600 

1920 

1921 

1922 

1923 

1924 

1925 

1926 

1927 




3210 

1672 

1673 

1674 

1675 

1676 

1677 

1678 

1679 


3610 

1928 

1929 

1930 

1931 

1932 

1933 

1934 

1935 




3220 

1680 

1681 

1682 

1683 

1684 

1685 

1686 

1687 


3620 

1936 

1937 

1938 

1939 

1940 

1941 

1942 

1943 




3230 

1688 

1689 

1690 

1691 

1692 

1693 

1694 

1695 


3630 

1944 

1945 

1946 

1947 

1948 

1949 

1950 

1951 




3240 

1696 

1697 

1698 

1699 

1700 

1701 

1702 

1703 


3640 

1952 

1953 

1954 

1955 

1956 

1957 

1958 

1959 




3250 

1704 

1705 

1706 

1707 

1708 

1709 

1710 

1711 


3650 

1960 

1961 

1962 

1963 

1964 

1965 

1966 

1967 




3260 

1712 

1713 

1714 

1715 

1716 

1717 

1718 

1719 


3660 

1968 

1969 

1970 

1971 

1972 

1973 

1974 

1975 




3270 

1720 

1721 

1722 

1723 

1724 

1725 

1726 

1727 


3670 

1976 

1977 

1978 

1979 

1980 

1981 

1982 

1983 




3300 

1728 

1729 

1730 

1731 

1732 

1733 

1734 

1735 


3700 

1984 

1985 

1986 

1987 

1988 

1989 

1990 

1991 




3310 

1736 

1737 

1738 

1739 

1740 

1741 

1742 

1743 


3710 

1992 

1993 

1994 

1995 

1996 

1997 

1998 

1999 




3320 

1744 

1745 

1746 

1747 

1748 

1749 

1750 

1751 


3720 

2000 

2001 

2002 

2003 

2004 

2005 

2006 

2007 




3330 

1752 

1753 

1754 

1755 

1756 

1757 

1758 

1759 


3730 

2008 

2009 

2010 

2011 

2012 

2013 

2014 

2015 




3340 

1760 

1761 

1762 

1763 

1764 

1765 

1766 

1767 


3740 

2016 

2017 

2018 

2019 

2020 

2021 

2022 

2023 




3350 

1768 

1769 

1770 

1771 

1772 

1773 

1774 

1775 


3750 

2024 

2025 

2026 

2027 

2028 

2029 

2030 

2031 




3360 

1776 

1777 

1778 

1779 

1780 

1781 

1782 

1783 


3760 

2032 

2033 

2034 

2035 

2036 

2037 

2038 

2039 




3370 

1784 

1785 

1786 

1787 

1788 

1789 

1790 

1791 


3770 

2040 

2041 

2042 

2043 

2044 

2045 

2046 

2047 
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Hev, B 




OCTAL-DECIMAL INTEGER CONVERSION TABLE (Cont'd) 




4000 

2048 

2049 

2050 

2051 

2052 

2053 

2054 

2055 


4400 

2304 

2305 

2306 

2307 

2308 

2309 

2310 

2311 

4010 

2056 

2057 

2058 

2059 

2060 

2061 

2062 

2063 


4410 

2312 

2313 

2314 

2315 

2316 

2317 

2318 

2319 

4020 

2064 

2065 

2066 

2067 

2068 

2069 

2070 

2071 


4420 

2320 

2321 

2322 

2323 

2324 

2325 

2326 

2327 

4030 

2072 

2073 

2074 

2075 

2076 

2077 

2078 

2079 


4430 

2328 

2329 

2330 

2331 

2332 

2333 

2334 

2335 

4040 

2080 

2081 

2082 

2083 

2084 

2085 

2086 

2087 


4440 

2336 

2337 

2338 

2339 

2340 

2341 

2342 

2343 

4050 

2088 

2089 

2090 

2091 

2092 

2093 

2094 

2095 


4450 

2344 

2345 

2346 

2347 

2348 

2349 

2350 

2351 

4060 

2096 

2097 

2098 

2099 

2100 

2101 

2102 

2103 


4460 

2352 

2353 

2354 

2355 

2356 

2357 

2358 

2359 

4070 

2104 

2105 

2106 

2107 

2108 

2109 

2110 

2111 


4470 

2360 

2361 

2362 

2363 

2364 

2365 

2366 

2367 

4100 

2112 

2113 

2114 

2115 

2116 

2117 

2118 

2119 


4500 

2368 

2369 

2370 

2371 

2372 

2373 

2374 

2375 

4110 

2120 

2121 

2122 

2123 

2124 

2125 

2126 

2127 


4510 

2376 

2377 

2378 

2379 

2380 

2381 

2382 

2383 

4120 

2128 

2129 

2130 

2131 

2132 

2133 

2134 

2135 


4520 

2384 

2385 

2386 

2387 

2388 

2389 

2390 

2391 

4130 

2136 

2137 

2138 

2139 

2140 

2141 

2142 

2143 


4530 

2392 

2393 

2394 

2395 

2396 

2397 

2398 

2399 

4140 

2144 

2145 

2146 

2147 

2148 

2149 

2150 

2151 


4540 

2400 

2401 

2402 

2403 

2404 

2405 

2406 

2407 

4150 

2152 

2153 

2154 

2155 

2156 

2157 

2158 

2159 


4550 

2408 

2409 

2410 

2411 

2412 

2413 

2414 

2415 

4160 

2160 

2161 

2162 

2163 

2164 

2165 

2166 

2167 


4560 

2416 

2417 

2418 

2419 

2420 

2421 

2422 

2423 

4170 

2168 

2169 

2170 

2171 

2172 

2173 

2174 

2175 


4570 

2424 

2425 

2426 

2427 

2428 

2429 

2430 

2431 

4200 

2176 

2177 

2178 

2179 

2180 

2181 

2182 

2183 


4600 

2432 

2433 

2434 

2435 

2436 

2437 

2438 

2439 

4210 

2184 

2185 

2186 

2187 

2188 

2189 

2190 

2191 


4610 

2440 

2441 

2442 

2443 

2444 

2445 

2446 

2447 

4220 

2192 

2193 

2194 

2195 

2196 

2197 

2198 

2199 


4620 

2448 

2449 

2450 

2451 

2452 

2453 

2454 

2455 

4230 

2200 

2201 

2202 

2203 

2204 

2205 

2206 

2207 


4630 

2456 

2457 

2458 

2459 

2460 

2461 

2462 

2463 

4240 

2208 

2209 

2210 

2211 

2212 

2213 

2214 

2215 


4640 

2464 

2465 

2466 

2467 

2468 

2469 

2470 

2471 

4250 

2216 

2217 

2218 

2219 

2220 

2221 

2222 

2223 


4650 

2472 

2473 

2474 

2475 

2476 

2477 

2478 

2479 

4260 

2224 

2225 

2226 

2227 

2228 

2229 

2230 

2231 


4660 

2480 

2481 

2482 

2483 

2484 

2485 

2486 

2487 

4270 

2232 

2233 

2234 

2235 

2236 

2237 

2238 

2239 


4670 

2488 

2489 

2490 

2491 

2492 

2493 

2494 

2495 

4300 

2240 

2241 

2242 

2243 

2244 

2245 

2246 

2247 


4700 

2496 

2497 

2498 

2499 

2500 

2501 

2502 

2503 

4310 

2248 

2249 

2250 

2251 

2252 

2253 

2254 

2255 


4710 

2504 

2505 

2506 

2507 

2508 

2509 

2510 

2511 

4320 

2256 

2257 

2258 

2259 

2260 

2261 

2262 

2263 


4720 

2512 

2513 

2514 

2515 

2516 

2517 

2518 

2519 

4330 

2264 

2265 

2266 

2267 

2268 

2269 

2270 

2271 


4730 

2520 

2521 

2522 

2523 

2524 

2525 

2526 

2527 

4340 

2272 

2273 

2274 

2275 

2276 

2277 

2278 

2279 


4740 

2528 

2529 

2530 

2531 

2532 

2533 

2534 

2535 

4350 

2280 

2281 

2282 

2283 

2284 

2285 

2286 

1\ .J7 


4750 

2536 

2537 

2538 

2539 

2540 

2541 

2542 

2543 

4360 

2288 

2289 

2290 

2291 

2292 

2293 

2294 

2295 


4760 

2544 

2545 

2546 

2547 

2548 

2549 

2550 

2551 

4370 

2296 

2297 

2298 

2299 

2300 

2301 

2302 

2303 


4770 

2552 

2553 

2554 

2555 

2556 

2557 

2558 

2559 


Octal Decimal 
10000 - 4096 


30000 1228B 
40000 - 16384 
50000 - 20480 
60000 ■ 24576 
70000 - 28672 


0 

1 

2 

3 

4 

5 

6 

7 

2560 

2561 

2562 

2563 

2564 

2565 

2566 

2567 

2568 

2569 

2570 

2571 

2572 

2573 

2574 

2575 

2576 

2577 

2578 

2579 

2580 

2581 

2582 

2583 

2584 

2585 

2586 

2587 

2588 

2589 

2590 

2591 

2592 

2593 

2594 

2595 

2596 

2597 

2598 

2599 

2600 

2601 

2602 

2603 

2604 

2605 

2606 

2607 

2608 

2609 

2610 

2611 

2612 

2613 

2614 

2615 

2616 

2617 

2618 

2619 

2620 

2621 

2622 

2623 

2624 

2625 

2626 

2627 

2628 

2629 

2630 

2631 

2632 

2633 

2634 

2635 

2636 

2637 

2638 

2639 

2640 

2641 

2642 

2643 

2644 

2645 

2646 

2647 

2648 

2649 

2650 

2651 

2652 

2653 

2654 

2655 

2656 

2657 

2658 

2659 

2660 

2661 

2662 

2663 

2664 

2665 

2666 

2667 

2668 

2669 

2670 

2671 

2672 

2673 

2674 

2675 

2676 

2677 

2678 

2679 

2680 

2681 

2682 

2663 

2684 

2685 

2686 

2687 

2688 

2689 

2690 

2691 

2692 

2693 

2694 

2695 

2696 

2697 

2698 

2699 

2700 

2701 

2702 

2703 

2704 

2705 

2706 

2707 

2708 

2709 

2710 

2711 

2712 

2713 

2714 

2715 

2716 

2717 

2718 

2719 

2720 

2721 

2722 

2723 

2724 

2725 

2726 

2727 

2728 

2729 

2730 

2731 

2732 

2733 

2734 

2735 

2736 

2737 

2738 

2739 

2740 

2741 

2742 

2743 

2744 

2745 

2746 

2747 

2748 

2749 

2750 

2751 

2752 

2753 

2754 

2755 

2756 

2757 

2758 

2759 

2760 

2761 

2762 

2763 

2764 

2765 

2766 

2767 

2768 

2769 

2770 

2771 

2772 

2773 

2774 

2775 

2776 

2777 

2778 

2779 

2780 

2781 

2782 

2783 

2784 

2785 

2786 

2787 

2788 

2789 

2790 

2791 

2792 

2793 

2794 

2795 

2796 

2797 

2798 

2799 

2800 

2801 

2802 

2803 

2804 

2805 

2806 

2807 

2808 

2809 

2810 

2811 

2812 

2813 

2814 

2815 

1 1 


2822 2823 
2830 2831 
2338 2839 
2846 2847 
2854 2855 
2862 2863 
2870 2871 
2878 2879 

2886 2887 

2894 2895 
2902 2903 
2910 2911 
2918 2919 

2926 2927 
2934 2935 

2942 2943 

2950 2951 
2958 2959 
2966 2967 
2974 2975 
2982 2983 

2990 2991 
2998 2999 

3006 3007 

3014 3015 

3022 3023 

3030 3031 

3038 3039 
3046 3047 

3054 3055 

3062 3063 

3070 3071 


Rev. A 








OCTAL-DECIMAL INTEGER CONVERSION TABLE (Cont'd) 


000 

3072 

to 

to 

777 

3583 

iciaO 

(Oecima 

Octal 

Decimal 

10000 

4096 

20000 

8192 

30000 

12288 

40000 

16384 

50000 

20480 

60000 

24576 

70000 

28672 



0 

1 

2 

3 

4 

5 

6 

7 

6000 

3072 

3073 

3074 

3075 

3076 

3077 

3078 

3079 

6010 

3080 

3081 

3082 

3083 

3084 

3085 

3086 

3087 

6020 

3088 

3089 

3090 

3091 

3092 

3093 

3094 

3095 

6030 

3096 

3097 

3098 

3099 

3100 

3101 

3102 

3103 

6040 

3104 

3105 

3106 

3107 

3108 

3)09 

3110 

3111 

6050 

3112 

3113 

31K4 

3115 

3116 

3117 

3118 

3119 

6060 

3120 

3121 

3122 

3123 

3124 

3125 

3126 

3127 

6070 

3128 

3129 

3130 

3131 

3132 

3133 

3134 

3135 

6100 

3136 

313? 

3138 

3139 

3140 

3141 

3142 

314j 
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.595703 

.561 

.720703 

.661 

.845703 

.761 

.970703 

.462 

.597656 

.562 

.722656 

.662 

.847656 

.762 

.972656 

.463 

.599609 

.563 

.724609 

.663 

.849609 

.763 

.974609 

.464 

.601562 

.564 

.726562 

.664 

.851562 

.764 

.976562 

.465 

.603515 

.565 

.728515 

.665 

.853515 

.765 

.978515 

.466 

.605468 

.566 

.730468 

.666 

.855468 

.766 

.980468 

.467 

.607421 

.567 

.732421 

.667 

.857421 

.767 

.982421 

.470 

.609375 

.570 

.734375 

.670 

.859375 

.770 

.984375 

.471 

.611328 

.571 

.736328 

.671 

.861328 

.771 

.986328 

.472 

.613281 

.572 

.738281 

.672 

.863281 

.772 

.988281 

.473 

.615234 

.573 

.740234 

.673 

.865234 

.773 

.990234 

.474 

.617187 

.574 

.642187 

.674 

.867187 

.774 

.992187 

.475 

.619140 

.575 

.744140 

.675 

.869140 

.775 

.994140 

.476 

.621093 

.576 

.746093 

.676 

.871093 

.776 

.996093 

.477 

.623046 

.577 

.748046 

.677 

.873046 

.777 

.998046 










OCTAL-DECIMAL FRACTION CONVERSION TABLE (Cont'd) 


OCTAL 

DEC. 

OCTAL 

DEC. 

OCTAL 

DEC. 

OCTAL 

DEC. 

.000000 

.000000 

.000100 

.000244 

.000200 

.000488 

.000300 

.000732 

.000001 

.000003 

.000101 

.000247 

.000201 

.000492 

.000301 

.000736 

.000002 

.000007 

.000102 

.000251 

.000202 

.000495 

.000302 

.000740 

.000003 

.000011 

.000103 

.000255 

.000203 

.000499 

.000303 

.000743 

.000004 

.000015 

.000104 

.000259 

.000204 

.000503 

.000304 

.000747 

.000005 

.000019 

.000105 

.000263 

.000205 

.000507 

.000305 

.000751 

.000006 

.000022 

.000106 

.000267 

.000206 

.00051 1 

000306 

.000755 

.000007 

.000026 

.000107 

.000270 

.000207 

.000514 

.000307 

.000759 

.000010 

.000030 

.000110 

.000274 

.000210 

.000518 

.000310 

.000762 

.000011 

.000034 

.000111 

.000278 

.00021 1 

.000522 

.000311 

.000766 

.000012 

.000038 

.000112 

.000282 

.000212 

.000526 

.000312 

.000770 

.000013 

.000041 

.000113 

.000286 

.000213 

.000530 

.000313 

.000774 

.000014 

.000045 

.000114 

.000289 

.000214 

.000534 

.000314 

.000778 

.000015 

.000049 

.000115 

.000293 

.000215 

.000537 

.000315 

.000782 

.000016 

.000053 

.000116 

.000297 

.000216 

.000541 

.000316 

.000785 

.000017 

.000057 

.000117 

.000301 

.000217 

.000545 

.000317 

.000789 

.000020 

.000061 

.000120 

.000305 

.000220 

.000549 

.000320 

.000793 

.000021 

.000064 

.000121 

.000308 

.000221 

.000553 

.000321 

.000797 

.000022 

.000068 

.000122 

.000312 

.000222 

.000556 

.000322 

.000801 

.000023 

.000072 

.000123 

.000316 

.000223 

.000560 

.000323 

.000805 

.000024 

,000076 

.000124 

.000320 

.000224 

.000564 

.000324 

.000808 

.000025 

.000080 

.000125 

.000324 

.000225 

.000568 

.000325 

.000812 

.000026 

.000083 

.000126 

.000328 

.000226 

.000572 

.000326 

.000816 

,000027 

.000087 

.000127 

.000331 

.000227 

.000576 

.000327 

.000820 

.000030 

.000091 

.000130 

.000335 

.000230 

.000579 

.000330 

.000823 

. 000031 

.000095 

.000131 

.000339 

.000231 

.000583 

.000331 

.000827 

.000032 

.000099 

.000132 

.000343 

.000232 

.000587 

.000332 

.000831 

.000033 

.000102 

.000133 

.000347 

.000233 

.000591 

.000333 

.000835 

.000034 

.000106 

.000134 

.000350 

.000234 

.000595 

.000334 

.000839 

.000035 

.000110 

.000135 

.000354 

.000235 

.000598 

.000335 

.000843 

.000036 

.000114 

.000136 

.000358 

.000236 

.000602 

.000336 

.000846 

.000037 

.000118 

.000137 

.000362 

.000237 

.000606 

.000337 

.000850 

.000040 

.000122 

.000140 

.000366 

.000240 

.000610 

000340 

.000854 

.000041 

.000125 

.000141 

.000370 

.000241 

.000614 

.000341 

.000858 

.000042 

.000129 

.000142 

.000373 

.000242 

.000617 

.000342 

.000862 

.000043 

.000133 

.000143 

.000377 

.000243 

.000621 

.000343 

.000865 

.000044 

.000137 

.000144 

.000381 

.000244 

.000625 

.000344 

.000869 

.000045 

.000141 

.000145 

.000385 

.000245 

.000629 

.000345 

.000873 

.000046 

.000144 

.000146 

.000389 

.000246 

.000633 

.000346 

.000877 

.000047 

.000148 

.000147 

.000392 

.000247 

.000637 

.000347 

.000881 

.000050 

.000152 

.000150 

.000396 

.000250 

.000640 

.000350 

.000885 

.000051 

.0001 56 

.000151 

.000400 

.000251 

.000644 

.000351 

.000888 

.000052 

.000160 

.000152 

.000404 

.000252 

.000648 

.000352 

.000892 

.000053 

.000164 

.000153 

.000408 

.000253 

.000652 

.000353 

.000896 

.000054 

.000167 

.000154 

. 000411 

.000254 

.000656 

.000354 

.000900 

.000055 

.000171 

.000155 

.000415 

.000255 

.000659 

.000355 

.000904 

.000056 

.000175 

.000156 

.000419 

.000256 

.000663 

.000356 

.000907 

.000057 

.000179 

.000157 

.000423 

,000257 

.000667 

.000357 

. 000911 

.000060 

.000183 

.000160 

.000427 

.000260 

.000671 

.000360 

.000915 

.000061 

.000186 

.000161 

.000431 

,000261 

.000675 

.000361 

.000919 

.000062 

.000190 

.000162 

.000434 

.000262 

.000679 

.000362 

.000923 

.000063 

.000194 

.000163 

.000438 

.000263 

.000682 

.000363 

.000926 

.000064 

.000198 

.000164 

.000442 

.000264 

.000686 

.000364 

.000930 

.000065 

.000202 

.000165 

.000446 

.000265 

.000690 

.000365 

.000934 

.000066 

.000205 

.000166 

.000450 

.000266 

.000694 

.000366 

.000938 

,000067 

.000209 

.000167 

,000453 

.000267 

.000698 

.000367 

.000942 

,000070 

.000213 

.000170 

.000457 

.000270 

.000701 

.000370 

.000946 

.000071 

.000217 

.000171 

.000461 

.000271 

.000705 

.000371 

.000949 

.000072 

.000221 

.000172 

.000465 

.000272 

.000709 

.000372 

.000953 

.000073 

000225 

.000173 

.000469 

.000273 

.000713 

000373 

.000957 

.000074 

.000228 

.000174 

.000473 

.000274 

.000717 

.000374 

.000961 

.000075 

.000232 

.000175 

.000476 

.000275 

.000720 

.000375 

.000965 

.000076 

.000236 

.000176 

.000480 

.000276 

.000724 

.000376 

.000968 

.000077 

.000240 

.000177 

.000484 

.000277 

.000728 

.000377 

.000972 
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OCTAL-DECIMAL FRACTION CONVERSION TABLE (Cont'd) 


OCTAL 

DEC . 

OCTAL 

DEC . 

OCTAL 

DEC . 

OCTAL 

DEC . 

.000400 

.000976 

.000500 

001220 

.000600 

.001464 

000700 

001708 

000401 

.000980 

000501 

.001224 

.000601 

.001468 

000701 

001712 

.000402 

.000984 

.000502 

.001228 

.000602 

.001472 

.000702 

.001716 

.000403 

.000988 

.000503 

.001232 

.000603 

.001476 

.000703 

001720 

.000404 

.000991 

.000504 

.001235 

.000604 

.001480 

.000704 

001724 

.000405 

.000995 

,000505 

,001239 

,000605 

,001483 

.000705 

001728 

.000406 

.000999 

.000506 

,001243 

.000606 

001487 

000706 

.001731 

.000407 

.001003 

,000507 

.001247 

.000607 

.001491 

.000707 

.001735 

.000410 

.001007 

.000510 

.001251 

.000610 

.001495 

.000710 

.001739 

.00041 1 

.001010 

.00051 1 

.001255 

.000611 

.001499 

000711 

001743 

.000412 

.001014 

.000512 

.001258 

.000612 

,001502 

.000712 

.001747 

.000413 

.001018 

.000513 

.001262 

.000613 

.001506 

.000713 

,001750 

.000414 

.001022 

.000514 

.001266 

.000614 

.001510 

.000714 

.001754 

.000415 

.001026 

.000515 

.001270 

.000615 

.001514 

.000715 

.001758 

.000416 

.001029 

.000516 

.001274 

.000616 

.001518 

.000716 

001762 

.000417 

.001033 

000517 

.001277 

.000617 

.001522 

.000717 

001766 

.000420 

.001037 

.000520 

.001281 

000620 

.001525 

000720 

001770 

.000421 

.001041 

.000521 

.001285 

.000621 

.001529 

000721 

001773 

.000422 

.001045 

.000522 

.001289 

.000622 

.001533 

000722 

001777 

.000423 

.001049 

.000523 

.001293 

.000623 

.001537 

.000723 

001781 

.000424 

.001052 

.000524 

.001296 

.000624 

.001541 

.000724 

.001785 

.000425 

.001056 

.000525 

.001300 

.000625 

.001 544 

.000725 

.001789 

.000426 

.001060 

.000526 

.001304 

.000626 

.001548 

.000726 

.001792 

.000427 

.001064 

.000527 

.001308 

.000627 

.001 552 

.000727 

.001796 

.000430 

.001063 

.000530 

.001312 

.000630 

.001556 

.000730 

.001800 

.000431 

.001071 

.000531 

.001316 

.000631 

.001560 

.000731 

.001804 

.000432 

.001075 

.000532 

.001319 

.000632 

.001564 

.000732 

.001808 

,000433 

.001079 

.000533 

.001323 

.000633 

.001567 

.000733 

.001811 

.000434 

.001083 

.000534 

.001327 

.000634 

.001571 

.000734 

.001815 

.000435 

.001087 

.000535 

.001331 

.000635 

.001575 

.000735 

.001819 

.000436 

.001091 

.000536 

.001335 

.000636 

.001579 

.000736 

.001823 

.000437 

.001094 

.000537 

.001338 

.000637 

.001583 

.000737 

.001827 

.000440 

.001098 

.000540 

.001342 

.000640 

.001586 

.000740 

.001831 

.000441 

.001102 

.000541 

.001346 

.000641 

.001590 

.000741 

.001834 

.000442 

.001106 

.000542 

.001350 

.000642 

.001594 

.000742 

.001838 

.000443 

.001110 

.000543 

.001354 

.000643 

.001598 

.000743 

.001842 

.000444 

.001113 

.000544 

.001358 

.000644 

.001602 

.000744 

.001846 

.000445 

,001117 

.000545 

.001361 

.000645 

.001605 

.000745 

.001850 

.000446 

.001121 

.000546 

.001365 

.000646 

.001609 

.000746 

.001853 

.000447 

.001125 

.000547 

.001369 

.000647 

.001613 

.000747 

.001857 

.000450 

.001129 

.000550 

.001373 

.000650 

.001617 

000750 

001861 

.000451 

.001132 

.000551 

.001377 

.000651 

.001621 

.000751 

.001865 

.000452 

.001136 

.000552 

.001380 

.000652 

.001625 

.000752 

.001869 

,000453 

.001140 

.000553 

.001384 

.000653 

.001628 

.000753 

001873 

.000454 

.001144 

.000554 

.001388 

.000654 

.001632 

.000754 

001876 

.000455 

.001 148 

.000555 

.001392 

.000655 

.001636 

.000755 

001880 

.000456 

.001152 

.000556 

.001396 

.000656 

001640 

.000756 

.001884 

.000457 

001155 

.000557 

.001399 

.000657 

.001644 

000757 

.001888 

.000460 

.001159 

.000560 

.001403 

.000660 

.001647 

.000760 

.001892 

.000461 

.001163 

.000561 

.001407 

.000661 

.001651 

.000761 

001895 

.000462 

.001167 

.000562 

.00141 1 

.000662 

.001655 

.000762 

.001899 

.000463 

.001171 

.000563 

.001415 

.000663 

001659 

.000763 

.001903 

.000464 

.001174 

.000564 

.001419 

.000664 

.001663 

.000764 

.001907 

.000465 

.001178 

.000665 

.001422 

.000665 

.001667 

000765 

,00191 1 

.000466 

.001182 

.000566 

.001426 

.000666 

.001670 

,000766 

.001914 

.000467 

.001186 

.000567 

.001430 

.000667 

.001674 

000767 

001918 

.000470 

.001190 

000570 

.001434 

.000670 

.001678 

.000770 

.001922 

000471 

.001194 

.000571 

.001438 

.000671 

001682 

000771 

001926 

.000472 

.001197 

000572 

001441 

.000672 

.001686 

,000772 

.001930 

.000473 

.001201 

000573 

.001445 

.000673 

.001689 

000773 

.001934 

.000474 

.001205 

000574 

.001449 

.000674 

,001693 

000774 

001937 

,000475 

.001209 

.000575 

.001453 

.000675 

.001697 

.000775 

,001941 

.000476 

.001213 

.000576 

.001457 

.000676 

.001701 

.000776 

.001945 

.000477 

.001216 

000577 

.001461 

.000677 

.001705 

.000777 

.001949 
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APPENDIX D 


INSTRUCTION FORMATS AND NOTES 



D. INSTRUCTION FORMATS AND NOTES 

The formats below correspond to the mnemonic instructions listed in Table D-1. 

23 18 17 15 14 00 

FI 

F2 

F3 
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F6 
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F9 
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TABLE D-1. INSTRUCTION FORMATS 


Mnemonic 

Code 

Basic 

Octal Code 

Instruction Format 

Page No. 

AC I 

77 

F4 

5-38 

ACR 

77 

F7 

5-40 

ADA, I 

30 

F3 

5-60 

ADAQ, I 

32 

F3 

5-61 

ADM 

67 

F18 

5-68 

AEU 

55 

FI 

5-36 

AIA 

53 

F6 

5-33 

AIS 

77 

F7 

5-37 

ANA 

17 

FI 

5-73 

ANA,S 

17 

FI 

5-73 

ANI 

17 

F3 

5-73 

ANQ 

17 

FI 

5-74 

ANQ, S 

17 

FI 

5-74 

AOS 

77 

F4 

5-37 

APF 

77 

F9 

5-39 

AQA 

53 

F5 

5-32 

AQE 

55 

FI 

5-36 

AQJ, EQ 

03 

F3 

5-46 

AQJ, GE 

03 

F3 

5-46 

AQJ, LT 

03 

F3 

5-46 

AQJ, NE 

03 

F3 

5-46 

ASE 

04 

FI 

5-29 

ASE, S 

04 

FI 

5-29 

ASG 

05 

FI 

5-30 

ASG, S 

05 

FI 

5-30 

ATD 

66 

F21 

5-119 

ATD, D 

66 

F22 

5-120 

AZJ, EQ 

03 

F3 

5-45 

AZJ, GE 

03 

F3 

5-45 

AZJ, LT 

03 

F3 

5-45 

AZJ, NE 

03 

F3 

5-45 

CIA 

77 

F4 

5-38 

CILO 

77 

F8 

5-91 
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TABLE D-1. INSTRUCTION FORMATS (Cont'd) 


Mnemonic 

Code 

Basic 

Octal Code 

Instruction Format 

Page No. 

FMU, I 

62 

F3 

5-66 

FRMT 

64 

F18 

5-147 

FSB, I 

61 

F3 

5-65 

HLT 

00 

FI 

5-24 

lAI 

53 

F6 

5-33 

lAPR 

77 

F4 

5-113 

IJD 

02 

F3 

5-44 

IJI 

02 

F3 

5-43 

INA 

15 

FI 

5-27 

INA, S 

15 

FI 

5-27 

INAC, INT 

73 

F14 

5-106 

INAW, INT 

74 

F14 

5-107 

INCL 

77 

F4 

5-89 

INI 

15 

F3 

5-27 

INPC; INT, B, H, G 

73 

F15 

5-98 

INPW, INT, B, N, G 

74 

F15 

5-100 

INQ 

15 

FI 

5-27 

INQ, S 

15 

FI 

5-27 

INS 

77 

F5 

5-85 

INTS 

77 

F5 

5-84 

lOCL 

77 

F4 

5-94 

ISA 

77 

F7 

5-37 

ISD 

10 

F3 

5-31 

ISE 

04 

F3 

5-28 

ISG 

05 

F3 

5-30 

IS I 

10 

F3 

5-31 

JAA 

77 

F4 

5-40 

JMP, HI A 

70 

FI 

5-42 

JMP, LOW A 

70 

FI 

5-42 

JMP, ZRO A 

70 

FI 

5-42 

LACK 

22 

F2 

5-49 

LBR 

70 

FI 

5-155 
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TABLE D-1. INSTRUCTION FORMATS (Cont'd) 


Mnemonic 

Code 

Basic 

Octal Code 

Instruction Format 

Page No. 

LCA, I 

24 

F3 

5-50 

LCAQ, I 

26 

F3 

5-51 

LDA, I 

20 

F3 

5-49 

LDAQ, I 

25 

F3 

5-50 

LDI, I 

54 

F3 

5-52 

LDL, I 

27 

.F3 

5-50 

LDQ, I 

21 

F3 

5-51 

LPA, I 

37 

F3 

5-73 

LQCH 

23 

F2 

5-52 

MEQ 

06 

FI 

5-75 

MOVE, INT 

72 

F16 

5-138 

MTH 

07 

FI 

5-76 

MUA, I 

50 

F3 

5-62 

MUAQ, I 

56 

F3 

5-63 

MVBF 

64 

F18 

5-142 

MVE 

64 

F18 

5-140 

MVE, D 

64 

F19 

5-141 

MVZF 

,64 

F18 

5-143 

MVZS 

64 

F18 

5-144 

MVZS, D 

64 

F19 

5-145 

OSA 

77 

F4 

5-37 

OTAC, INT 

75 

F14 

5-109 

OTAW, INT 

76 

F14 

5-110 

OUTC, INT, B, H 

75 

F15 

5-102 

OUTW, INT, B, N 

76 

F15 

5-104 

PAK 

66 

F18 

5-121 

PA US 

77 

Fll 

5-87 

PFA 

77 

F9 

5-39 

PRP 

77 

Fll 

5-88 

QEL 

55 

FI 

5-36 

QSE 

04 

FI 

5-29 

QSE, S 

04 

FI 

5-29 
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TABLE D-1. INSTRUCTION FORMATS (Cont'd) 


Mnemonic 

Code 

Basic 

Octal Code 

Instruction Format 

Page No. 

QSG 

05 

FI 

5-30 

QSG, S 

05 

FI 

5-30 

RAD, I 

34 

F3 

5-60 

RIS 

55 

FI 

5-112 

ROS 

55 

FI 

5-112 

RTJ 

00 

FI 

5-47 

SACK 

42 

F2 

5-54 

SBA, I 

31 

F3 

5-61 

SBAQ, I 

33 

F3 

5-61 

SB CD 

77 

F4 

5-91 

SBJP 

77 

F4 

5-112 

SBM 

67 

F18 

5-69 

SBR 

70 

FI 

5-155 

SCA, I 

36 

F3 

5-72 

SCAN, LR, EQ, DC 

65 

F26 

5-130 

SCAN, LR,NE, DC 

65 

F26 

5-132 

SCAN, RL, EQ,DC 

65 

F2 6 

5-134 

SCAN, RL, NE, DC 

65 

F26 

5-136 

SCAN, LR, EQ 

65 

F2 6 

5-129 

SCAN, LR, NE 

65 

F26 

5-131 

SCAN, RL, EQ 

65 

F2 6 

5-133 

SCAN, RL, NE 

65 

F2 6 

5-135 

SCAQ 

13 

F3 

5-59 

SCHA, I 

46 

F3 

5-56 

SCIM 

77 

F4 

5-90 

SDL 

77 

F7 

5-113 

SEL 

77 

F12 

5-96 

SFPF 

77 

F4 

5-91 

SHA 

12 

F3 

5-57 

SHAQ 

13 

F3 

5-59 
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TABLE D-1. INSTRUCTION FORMATS (Cont'd) 


Mnemonic 

Code 

Basic 

Octal Code 

Instruction Format 

Page No. 

SHQ 

12 

F3 

5-59 

SJl 

00 

FI 

5-41 

SJ2 

00 

FI 

5-41 

SJ3 

00 

FI 

5-41 

SJ4 

00 

FI 

5-41 

SJ5 

00 

FI 

5-41 

SJ6 

00 

FI 

5-41 

SLS 

77 

F4 

5-24 

SQCH 

43 

F2 

5-55 

SRCE,INT 

71 

F13 

5-125 

SRCN, INT 

71 

F13 

5-127 

SSA, I 

35 

F3 

5-72 

SSH 

10 

FI 

5-57 

SSIM 

77 

F4 

5-90 

STA, I 

40 

F3 

5-53 

STAQ, I 

45 

F3 

5-54 

STI, I 

47 

F3 

5-56 

STO, I 

41 

F3 

5-55 

SWA, I 

44 

F3 

5-56 

TAI 

53 

F6 

5-33 

TAM 

53 

FIO 

5-34 

TIA 

53 

F6 

5-33 

TIM 

53 

FIO 

5-35 

TMA 

53 

FIO 

5-34 

TMAV 

77 

F4 

5-81 

TMI 

53 

FIO 

5-35 

TMQ 

53 

FIO 

5-34 

TQM 

53 

FIO 

5-34 

TST 

67 

F17 

5-82 

TSTN 

67 

F17 

5-82. 0 

UCS 

77 

F4 

5-24 

UJP, I 

01 

_ 

F3 

5-41 
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TABLE D-1. INSTRUCTION FORMATS (Cont'd) 


Mnemonic 

Code 

Basic 

Octal Code 

Instruction Format 

Page No, 

UPAK 

66 

F18 

5-122 

XOA 

16 

FI 

5-71 

XOA, S 

16 

FI 

5-71 

XOI 

16 

F3 

5-71 

XOQ 

16 

FI 

5-71 

XOQ, S 

16 

FI 

5-71 

ZADM 

67 

F18 

5-146 
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APPENDIX E 

MULTIPROGRAMMING AND RELOCATION 
SUPPLEMENTARY INFORMATION 



E. MULTIPROGRAMMING AND RELOCATION 
SUPPLEMENTARY INFORMATION 


Multiprogramming in the 3300 Computer System enables the instructions of 
many programs to be sequentially executed by controlled time-sharing 
operations within a processor. With the Control Data Multiprogramming Mod¬ 
ules, throughput is very high due to efficient use of hardware and optimum 
program scheduling. This feature is very desirable at installations where 
numerous jobs are run and computing time must be kept at a minimum. Systems 
equipped with the relocation feature can compute many programs on a time- 
shared basis or be switched into the non-Executive mode and process jobs 
according to control card job assignments. 


EXECUTIVE MODE 


A system equipped with relocation hardware and operating in the Executive 
Mode functions in either the Monitor State or the Program State. 


Monitor State 


The Monitor State is the initial operating state of a master cleared processor. 
The processor also reverts to this state if interrupted for any condition. All 
instructions may be executed in the Monitor State. 


Program State 

The Program State permits all but the following instructions to be executed; 

1. A Halt instruction (00. 0) 

2. Any of the instructions with function codes in the 71-77 range including the 
UCS, except the SPPP (77.71) and SBCD (77. 72) instructions. 

3. An inter-register transfer instruction that attempts to alter registers 
00 through 3 7 of the register file. 
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If an attempt to execute one of these instructions occurs, an Executive interrupt 
is generated and operating control is transferred back to the Monitor State. The 
Executive interrupt is not masked and the interrupt system need not be enabled 
to recognize the interrupt when it occurs. Upon recognition, the Executive 
interrupt transfers program control to the Monitor State. The instruction that 
caused the interrupt is not executed. The following flow chart describes the 
sequence of events involved when an Executive Interrupt occurs. 

EXECUTIVE INTERRUPT SEQUENCE 



MULTIPROGRAMMING AND RELOCATION 


If the 3311 Multiprogramming option is not present in a 3300 system, the maximum 
number of MCS words is 131,072. The actual address referenced is as follows: 


(ISR)- 

(OSR) 


t7 BIT ADDRESS 

_A_ 

/- 

0100 14 


-V 

00 

B 

n 

(P) 



I OR ; 

01 OOi 



1, Of* I 
00 " 


Rev. A 


Upper Bit of ISR 
or OSR is ignored 


E-2 


Refer to Table E-1 for conditions 
when (ISR), (OSR), or zero is 
appended to address P. 










If the APF (77. 64) or PFA (77. 65) instructions are executed they become no¬ 
operation instructions when the 3311 is not present. The keyboard sweep and enter 
functions with the Page Index File are also disabled. All other operating conditions 
are the same whether or not the 3311 is in the system. 

A 3300 CPU can access up to 262,144 words of core storage when the 3311 
Multiprogramming option and appropriate storage modules are present in the 
system. This is accomplished by augmenting the basic 15-bit address P with a 
3-bit state number. The state number^ along with a portion of the 15-bit address, 
becomes the direction path into a relocation path. From the Page Index File the 
correct page address is obtained for actual memory addressing. 


Page Structure 

Each page of memory is assigned 2 , 048 absolute memory locations. A fully 
expanded system contains 128 of these pages. Individual pages may be sub¬ 
divided into four partial pages. A 1/4 page consists of 512 address locations. 
Programs may be allocated full pages, 3/4 page, l/2 page or 1/4 page of 
memory. 

To facilitiate addressing with the paging scheme, a word organized core 
matrix is used. This core matrix, called the Page Index File, is referenced 
by a program during a memory reference to obtain the physical page address 
or partial page address and provide memory protection. 

Address Relocation 


Figure E-1 illustrates address bits at various stages of the relocation process. 
Those portions of the diagram accompanied by circled numbers are further 
described in the following numbered paragraphs. 

(T) Program Address and Program Address Group 

Any program executed by a 3300 is processed within the confines of a 15-bit 
program address structure. These 15 bits define the program or operand 
address related to the routine or subroutine being processed at a given instant. 
Figures E-2 and E-3 illustrate the significance of these bits in the instruction 
words for both word addressing and character addressing. 

The 15 bits used in word addressing define an absolute address assignment 
ranging from 00000 to 77777g. Any program or group of programs within this 
range of addresses which can be compiled and loaded without conflicting add¬ 
resses can be considered part of a program address group. Figure E-4is 
illustrative of a program address group consisting of five non-conflicting 
programs. 
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Figure E-1. Address Relocation Process 
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A program address group may be considered apart from the physical memory 
structure since it is a group of sequentially numbered addresses representing 
one or more programs within 32, 768 words of storage and not a discrete 
physical device. Many program address groups may be contained in storage; how¬ 
ever, eight such groups are used in the 3300 to best optimize the memory system. 


23 


18 17 IS 14 


00 


FUNCTION 

CODE 


WORD 

ADDRESS 
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BITS 
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Figure E- 

2. 

Word Addressing 


23 18 

17 16 



00 


FUNCTION 


CHARACTER 

CODE 


ADDRESS 

K-6 BITS--17 BITS-H 


Figure E-3. Character Addressing 


(D Instruction State Register (ISR) and Operand State Register (OSR) 

The ISR and OSR define the specific program address group currently being 
accessed by a processor. The program address group being referenced for 
instructions and operands can assume any one of eight discrete values by 
modifying the contents of these single digit registers. By transferring dis¬ 
similar numbers into these registers, instructions and operands may ref¬ 
erence different program address groups. 

The contents of these registers can only be changed by the Executive routine in 
the Monitor State. 

The program address group that is currently valid for memory references is 
selected by the contents of the ISR or OSR. Table E-1 describes the selecting 
conditions. 
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00000 


ADDRESSES 



PROGRAM 

A 

PROGRAM 

B 

PROGRAM 

C 

PROGRAM 

D 

PROGRAM 

E 


Figure E-4. Program Address Group 


TABLE E-1. INSTRUCTION AND OPERAND REFERENCING 


Operational State of the Processor 

Instructions 
Referenced With: 

Operands 
Referenced With: 

Initial Monitor State 

Zero 

Zero 

Monitor State and 55.4 (relocate 
to operand state) instruction 
executed 

Zero 

Contents of OSR 

Transition from Monitor State to 
Program State 

Contents of ISR 

Contents of ISR* 

Program State and 55.4 (relocate 
to operand state) instruction 
executed 

Contents of ISR 

Contents of OSR 

Program State and 55.0 (relocate 
to instruction state) instruction 
executed 

Contents of ISR 

Contents of ISR 

Any interrupt condition to 

Monitor State 

Zero 

Zero 


^Transition from Monitor State to Program State does not change the operand 
address mode. 
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® Page Index File 


The Page Index File is functionally divided into eight distinct reference areas. 
One area is associated with each of eight possible numbers appearing in the ISR 
and OSR. Because of this direct relationship, each of the eight program address 
groups is permanently assigned a reference area in the Page Index File. 

Each of the eight reference areas within the Page Index File consists of sixteen 
12-bit Page Index Registers. This provides each of the program address groups 
exclusive use of 16 of these registers. By using the upper 4 bits of the program 
address for direction to the respective Page Index Registers, a direct and 
sequential relationship is established between the addresses in a program ad¬ 
dress group and a specific set of 16 Page Index registers. The Page Index File 
is actually constructed of 64 24-bit Page Index registers with dual 12-bit in¬ 
dexes. Only one of the 12-bit indexes is used during any specific reference. 

Figure E-6 depicts the page indexes within the Page Index File and Figure E-7 
illustrates the relationship between program address groups. Page Index File, 
and a fully expanded core memory. 

Bit 11 of the original 15-bit address determines which of the two page indexes 
at the Page File location will be used. Figure E-5 shows a specific page index 
being referenced. 


(ISR) 
02 00 


PROGRAM ADDRESS (P) 
14 12 II 10 


00 



INDICATES ODD PAGE 
index at LOCATION 23 


>23 


SECTION OF PAGE FILE 
12 II 


\\ 

W 

\\ 

\v 

\ 


001 


2,r 

L 

PAGE 

INDEX 

2 1 

0 

1 PAGE 

INDEX 

2 1 

T! 

1 

1 

22, 

PAGE 

INDEX 

22 

0 

^ PAGE 

1 

INDEX 

22 

1 

23| PAGE 

INDEX 

23 

0 

\ 



- 

1 

241 

L 

PAGE 

INDEX 

24 

0 

jW 

INDEX 

24 



s 

\ 

\ \ 

\ N 
\ \ 

\ \ 

\\ 

\ \ 


PAGE INDEX 23 I 


The contents of this Page Index (E, 
PL, PA, and PP) are used to form 
the relocated'address. The format 
of a page index is shown below. 


II 10 OS OS 02 01 00 


E 

PL 

PA 

PP 1 


Figure E-5. 


Example of Page Index Referencing 
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•THIS DIGIT INDICATES 
PROGRAM STATE NUMBER 


PAGE INDEX 01 


PAGE INDEX 02 0 


PAGE INDEX 03 0 


PAGE INDEX 04 0 


PAGE INDEX 09 O 


PAGE INDEX 06 0 


PAGE INDEX .07 0 


PAGE INDEX 10 O 


PAGE INDEX I I 


PAGE INDEX 12 


PAGE INDEX 


page INDEX 01 


PAGE INDEX 02 


PAGE INDEX 03 


PAGE INDEX 04 < 


PAGE INDEX 09 I 


PAGE INDEX 06 


PAGE INDEX 07 


PAGE INDEX 10 


PAGE INDEX I I 


PAGE INDEX 12 


PAGE INDEX I 3 


PAGE INDEX 71 


PAGE INDEX 72 


PAGE INDEX 73 0 


PAGE INDEX 74 


PAGE INDEX 79 


PAGE INDEX 76 0 


PAGE INDEX 77 


PAGE INDEX 7 I 


PAGE INDEX 7 2 


PAGE INDEX 7 3 


PAGE INDEX 74 


1- 

INDEX 

75 

1 PAGE 

PASE 

INDEX 

76 

1 PAGE 

INDEX 

77 


ADDRESSES 


ADDRESSES 


Figure E-6. Page Index File Address and Hardware Structure 
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REGISTERS 


MONITOR 

PROGRAM 


PROGRAM 
ADDRESS 
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EACH PRO- _ 

GRAM ADDRESS | 

GROUP CONSISTS PROGRAM 
OF ONE OR MORE ADDRESS 
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PROGRAM 
ADDRESS 
GROUP 3 


PROGRAM 
ADDRESS 
GROUP 4 


PROGRAM 
ADDRESS 
GROUP 5 


PROGRAM 
ADDRESS 
GROUP 6 


PROGRAM 
ADDRESS 
GROUP 7 


Figure E-7. 


EACH PROGRAM 
ADDRESS GROUP 
HAS ACCESS TO 
16 UNIQUE PAGE 
INDEXES 



Relocation System Illustrating Memory Protection 
with Fully Expanded Memory (262K) 
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1587 


(4) Page Index 

Each page index has the same basic format. The significance of each designator 
during the relocation process is described below. Figure E-8 shows the format 
for a page index while Figure E-9 shows a view of the display panel on the re¬ 
location chassis. 


II 10 09 08 

OR OR OR OR 

23 22 21 20 


02 01 00 ^ 

OR OR OR 

14 13 \zS 


E 

PL 

PA 

PP 


ACTUAL BITS DEPEND 
UPON WHETHER THE 
EVEN OR ODD PAGE 
INDEX IS REFERENCED 


E = EXCLUSION BIT (I BIT) 

PL* PAGE LENGTH DESIGNATOR (2 BITS) 

PA = PAGE ADDRESS DESIGNATOR (TBITS) 

PP= PARTIAL PAGE DESIGNATOR (2 BITS) 

Figure E-8. Page Index Format 


E - Exclusion bit 


This designator may have one of three meanings; 

1. If E = "O", the quantity expressed by PA defines a page* 
where either reading or writing is permitted. 

2. If E = "l", and PL, PA or PP is a quantity other than 
zero, PA defines a page * where only reading is per¬ 
mitted, If a write is attempted, an Illegal Write inter¬ 
rupt is generated. 

3. If E = "1” and PL, PA Or PP are all equal to zero, 
an unaddressable page is defined and an Illegal Write 
interrupt is generated by the Page Index File. 

* Refer to descriptions of PL and PP designators for page restrictions. 
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Figure E-9. Relocation Chassis Display Panel 
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PA - Seven bits are used to define the actual memory module being referenced. 
As stated earlier in this manual, there may be 128 segmented pages in a 
3300 system with 262, 144 words of core storage. Each page has 
a unique page address and addresses 000 through ITYg define all of the 
possible pages. 

A 3300 system with a fully expanded storage network has two address 
busses. Each bus has access to 131,072 words of the total 262,144 
storage words. The uppermost bit of PA (bit 17 in the relocated address) 
determines which bus (right or left) is selected. This bit will be a "l" 
when the left bus is used and a "O" when the right bus is selected. Figure 
E-10 depicts the bus address system. 



Figure E-10. Storage Address Buses 


QUARTER PAGE 
ADDRESSES FOR < 
PAGE O 



note; pp:0 FOR THIS EXAMPLE 

PL = 0 FOR FULL PAGE PL * 2 FOR 1/2 PAGE 

PL = I FOR 1/4 PAGE PL = 3 FOR 3/4 PAGE 


Figure E-11. Page Length Subdivisions 
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PL - Each page has 2, 048 memory locations and is subdivided into quarters of 
512 locations each. The PL designator defines how many quarters of a 
page can be referenced (beginning with the starting quarter specified by 
PP). A program is assigned the number of quarter pages it needs to re¬ 
side in memory. Figure E-11 illustrates the quarter sections of a page 
and the significance of the PL bits, 

PP - The Partial Page designator is the address of the physical quarter page 

that will serve as the starting point of the page. Example A (Figure E-12) 
shows the quarter page referenced for each of the PP designators. The 
significance of the PP designator in selecting the respective quarter page 
for addressing is described below.. 

EXAMPLE A 


PHYSICAL 

QUARTER 

DESIGNATOR 

I 

STARTING QUARTER —> 


PP»0 


|ST 

QUARTER 

2 ND 

QUARTER 

3 RD 

QUARTER 

4 TH 

QUARTER 


RELATIVE QUARTER 
IN RESPECT TO THE 
STARTING QUARTER 

I 


3 


STARTING QUARTER 

PP = I 


|ST 

QUARTER 

2 ND 

QUARTER 

3 RD 

QUARTER 

4 TH 

QUARTER 


4 

1 

2 
3 


STARTING QUARTER 


|ST 

QUARTER 

2 ND 

QUARTER 

3 RD 

QUARTER 

4 TH 

QUARTER 


3 

4 

1 

2 


PP= 3 


STARTING QUARTER 


|ST 

QUARTER 

2 ND 

QUARTER 

3 RD 

QUARTER 

4 TH 

QUARTER 


2 

3 

4 
I 


Figure E-12. Quarter Page in Relation to PP Designator 


Rev. B 


E-12 







If PP = 0, the relative page begins in the 1st physical quarter 

If PP = 1, the relative page begins in the 2nd physical quarter 

If PP = 2, the relative page begins in the 3rd physical quarter 

If PP = 3, the relative page begins in the 4th physical quarter 


(D Partial Page Adder 

A special adder is used to combine the PP designator from the page index with 
bits 9 and 10 of the original address. The partial sum indicates the address of the 
physical quarter in which referencing will begin. Example B and Figure E-13 
show the actual quarter page in which addressing occurs for specific PL, PP, and 
bits 9 and 10 values. 


EXAMPLE B 


PL = 0 
PP = 1 

Bits 9 and 10 = 2 


Analysis: A full page (PL = 0) is allocated, the relative page 

begins in the second physical quarter, and referen¬ 
cing begins in the fourth physical quarter, (physical 
quarter address 3). 


STARTING QUARTER 


PP= I 


BITS 9 AND 10 = 2 



ADDRESSING STARTS IN THE 
THIRD RELATIVE QUARTER 
(FOURTH PHYSICAL QUARTER) 


Figure E-13. Starting Quarters versus Relative Quarters 


It should be noted that if bits 9 and 10 of the original address specify a quarter 
page equal to or greater than that of the PL designator when PL f zero, an Illegal 
Write interrupt will occur. An example of this condition would be a 1/4 page 
allocated but bits 9 and 10 equal to 3, thus specifying an address in the fourth 
quarter. 

This interrupt will not occur during Monitor State or I/O operations. 
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(D Relocated Address 


The 18-bit relocated address defines the actual core storage location being 
referenced. 

The PA portion of the page index fills the upper seven bits of this address (S) 
bus to use and select the appropriate storage module. Bits 9 and 10 receive the 
output of the adder previously described and indicate the physical quarter page 
being referenced. The lower nine bits are unaltered from the original address 
and comprise the remainder of the relocated address. 


Page Zero Consideration 

If page Index File address zero is referenced in either the Program or Monitor 
state, the PA and PP designators for this page index will always be zero. As 
a result of this condition, page zero, which encompasses addresses 000000 
through 003777, can be accessed and used for storing the Auto Load and Auto 
Dump routines. The Auto Load routine is contained in addresses 003700 
through 003737 and the Auto Dump routine is stored in addresses 003740 through 
003777. 
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BUSINESS DATA PROCESSING SUPPLEMENTARY INFORMATION 



F. BUSINESS DATA PROCESSING SUPPLEMENTARY INFORMATION 


The performance of a 3300 computing system is further enhanced by the addition 
of a 3312 Business Data Processor (BDP) which eliminates the need for simulating 
subroutines. Business-oriented rnoves and edits, searches, code conversions and 
translations as well as BCD arithmetic operations are executed directly by the 
BDP. Since the BDP is designated as an integral part of the computer system and 
interfaces directly to the magnetic core storage modules, the instructions are 
executed with great speed. The BDP expands the basic instruction repertoire to 
cover instructions inherent to business data processing applications. 

The logical organization of the BDP and its comprehensive instruction repertoire 
emphasizes its usefulness as a logical field processor. This organization per¬ 
mits truly efficient processing of highly structured data files. Some examples 
of applications which exploit these features are data collection, production con¬ 
trol, inventory accounting, and financial and accounting systems. 


CHARACTERISTICS OF BDP 

The following are characteristics of the 3300 Business Data Processor: 

c Character addressing and manipulation 

internal BCD 6-bit characters 
24-bit words 

• Manipulation of data organized in variable or fixed length fields 

• Memory to memory operations 

• Field limits expressed by either programmer-defined delimiter 
or by length 

• COBOL specification compatibility 

• Error indications on arithmetic overflow and illegal characters 

• Algebraic sign control 
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• Extremely fast and comprehensive data processing instruction set 

moves and edits 
searches 

ASCII/BCD code conversions and translations 
arithmetic functions 

• System interrupt capability retained without loss of data 

Business data processing instructions are listed in Section 5. A general de¬ 
scription of each of the instruction categories is listed below: 


MOVES AND EDITS 


The following capabilities are features of this instruction category: 

• Ability to transfer variable length data fields from one area 
of storage 

• Both fields may specify any 6-bit character location in storage 
as the beginning address 

• Both fields may be independently indexed 

• Up to 4095 characters may be processed 

• Operations may be terminated by specifying lengths of fields 
or by encountering delimiting characters; field lengths may 
differ 

• Data moved from a source field to a receiving field may be 
manipulated and/or modified as follows: 

► Single character or block of characters transferred without 
modification 

► Move with blanks inserted in any remaining character 
positions in the receiving field 

► Move with zeros inserted in any remaining character 
positions in the receiving field 

► Move with leading zeros replaced with blanks and zone 
(sign) bits stripped during the transfer 

► Move with edit functions performed: insertion of commas, 
decimal point with suppression of leading zeros, or complete 
formatted edit with insertion of character set as defined in 
DOD COBOL-61 Extended specification 

Instructions in this group are particularly useful in data processing applications 
involving character manipulation, formatting for printing of integer quantities, 
point alignment problems, etc. Editing functions are accomplished by hardware 
rather than a complex subroutine, resulting in extremely fast processing times. 
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SEARCHES 


The following capabilities are features of this category of instructions: 

<a Any 6-bit character location in storage may be specified as 
the location of the first character to be searched 

• Up to 4095 characters may be examined 

o Indexing may be accomplished on the search field 

• Search key (character) specified by programmer and contained 
in instruction word 

• Search may be terminated by: 

► Locating object character 

► Completing specified number of searches without 
locating object character 

► Encountering delimiter-character without locating 
object character 

• At conclusion of search operation, an index register holds number of 
characters searched to aid in determining location of character meeting 
search condition; this information placed in Central Processor Index 
register 

• Program control at search termination branches to either of two points, 
depending on result of search 

• Searches may be of the following types; 

► Search successive character locations (either left to right 
or right to left) in a field for an object character equal to 
the search key 

► Search successive character locations (either left to right 
or right to left) in a field for an object character unequal 
to the search key 

► Search successive character locations (from left to right) 

in a field for an object character equal to the search key and 
jump; jump is to normal termination point plus the number 
of characters searched 


CONVERSIONS AND TRANSLATIONS 


Instructions in the category provide conversion and translation abilities to ef¬ 
ficiently process data of varying formats. Translating codes prepares data for 
various operations preliminary to the actual data processing. Translations to 
and from the American Standard Code for Information Interchange (ASCII) code 
provide compatibility with other systems data handling schemes. An ASCII to 
BCD conversion table can be found in Appendix A. 
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The following conversions and translations may be effected with this category of 
instructions: 

• Convert BCD to binary 

• Convert binary to BCD 

• Translate to ASCII 

• Translate from ASCII 

• Pack (convert numeric 6-bit digits into 4-bit BCD characters) 

• Unpack (convert numeric 4-bit digits into 6-bit characters) 


ARITHMETIC FUNCTIONS 


The following capabilities are features of this category of instructions: 

• Arithmetic performed on 6-bit BCD characters 

• Both fields may specify any 6-bit character location in storage 
as the beginning address 

• Both fields may be independently indexed 

• Algebraic sign control 

• Arithmetic overflow fault indicator provided 
e Arithmetic operations from right to left 

• Compare - comparisons of two fields for equal, unequal 

► Compare left to right 

► Delimiter or number of characters (up to 4095) 
specifies number of characters to be compared 

► High-low indication held in condition register 
for examination by Jump instructions 

• Test instructions examine field for: greater than zero, 
zero, or less than zero. The result of the test sets a 
BCD condition register to +, 0, or - 

o Jump instructions in the CPU may be used to examine 
arithmetic result flags in the BDP 

Consult the individual business data processing instructions in Section 5 for 
detailed information pertaining to each type of instruction. 


BCD CHARACTERS AND ALGEBRAIC SIGN POSITIONS 


Six-bit BCD characters are used during most BDP operations. The following 
diagrams, example, and tables show the character placements and sign positions: 
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23 


18 17 


12 11 


06 ' 05 


00 



BCD Character 



Sign bits Character bits 


Figure F-1. BCD Word and Character Format 

TABLE F-1 . BCD SIGN BIT POSITIONS 


Sign of BCD 
Field 

Relative Bit Positions 

6 

5 

+ 

0 

0 

+ 

0 

1 

- 

1 

0 

+ 

1 

_1 

1 


TABLE F-2, DECIMAL/BCD CHARACTER FORMAT 


Decimal 

Number 

BCD Character Relative Bit 

Positions 

4 

3 

2 

1 

0 

0 

0 

0 

0 

1 

0 

0 

0 

1 

2 

0 

0 

1 

0 

3 

0 

0 

1 

1 

4 

0 

1 

0 

0 

5 

0 

1 

0 

1 

6 

0 

1 

1 

0 

7 

0 

1 

1 

1 

8 

1 

0 

0 

0 

9 

1 

0 

0 

1 
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EXAMPLE; Execute the MVZF instruction at P, P + 1, and P + 2. 

P =64000202 
P + 1 = 27003000 
P + 2= 00140017 

Analysis: 

1. The unmodified character address 'r' is 00202. 

2. Bj, = 3, requiring (B^) be added to r. If (B^) = 00200 then 

R = 00402 which equals word address 00100 character position 
2. This is the true address of the highest order character in field A. 

2 

3. Bg = 2, requiring^(B ) be added to the unmodified character address 
's', 03000. If (^) = 01000, then S = 04000. 

4. The length of the A field is 14o characters and the alloted length of the C 
field is 17g characters. The fast three characters of field C will be 
filled with zeros. The last character of field C (a zero) will also contain 
the sign of the field. 

'A' Field 
Word Addresses 
0 0 10 0 
0 0 10 1 
0 0 10 2 
0 0 10 3 


Character Positions 

Highest Order 
Character in 
Field A 

0 1 1 1 0 2 0 4 

^ . Operand Specified 

06031110 Field A Equals 

0 5 (S^ 0 4 0 7 -431924639859 



(B^) = 00200 
(B^) = 01000 


Lowest Order 
Character in 
Field A 



5 1 


Indicates a 


10 10 0 1 



Negative Field 


Is llg = 9io 
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The operation proceeds as follows: 


First Character Stored Is 
Highest Order Character At 
Word Address OlOOOj Char¬ 
acter Position Zero. 


'C Field 
Word Addresses 


0 

0 

7 

7 

7 

0 


0 

1 

0 

0 

0 

1 

0 

0 

0 

(4 


0 

3 

0 

1 

0 

1 

0 

0 

1 

0 

2 

0 

4 

0 

6 

0 

1 

0 

0 

2 

1 

1 

1 

0 

0 

5 

0 

1 

0 

0 

3 

0 

0 

0 

0 

(S' 



0 2 /Sign Is No Longer Stored 

, . In This Character As The 

Lowest Order Character 
0 3 / Of Field C Is Now Char- 

^ acter Position 2 Of Word 

^ Address 01003. 

0 7 


Lowest Order Character Operand Now Stored 

In Field C Contains the In Field C Equals 

Sign of Field C (minus) -431924639859000 

and a Zero Character. 
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GLOSSARY 


The definitions of terms in this glossary are general, and are oriented toward 

their application to the 3300 computer. The definitions should not be construed as 

absolute or applicable for all Control Data products. 

A REGISTER - Principal arithmetic register; operates as a 24-bit additive 
accumulator (modulus 224-i), 

ABSOLUTE ADDRESS - An address at a specific memory location. 

ACCESS TIME - The time needed to perform a storage reference, either read 
or write. In effect, the access time of a computer is one storage reference 
cycle. 

ACCUMULATOR - A register with provisions for the addition of another quantity 
to its content. 

ADDER - A device capable of forming the sum of two or more quantities. 

ADDRESS - A 15-bit operand which identifies a particular storage location; a 
17-bit operand which identifies a particular character location in storage. 

ADDRESS MODIFICATION - Normally the derivation of a storage address from 
the sum of the execution address and the contents of the specified index 
register. 

AND FUNCTION - A logical function in Boolean algebra that is satisfied (has 

the value "l") only when all of its terms are "I's". For any other combina¬ 
tion of values it is not satisfied and its value is "O”. 

ARGUMENT - An operand or parameter used by a program or an instruction. 

ASCII CODE - American Standard Code for Information Interchange 8-bit 
character code (eighth bit is actually unassigned). 

ASSEMBLER - A program which translates statements to machine language. 
Normally, one source language statement results in the generation of one 
line of object code. 


Glossary - 1 


Rev. A 



1 O o 

B , B , B"^ REGISTERS - Index registers used primarily for address modifi¬ 
cation and/or counting. 

BASE - A quantity which defines some system of representing numbers by 
positional notation; radix. 

BDP - (1) Business Data Processor (3312); provides the necessary hardware 
to execute business oriented instructions. Contains its own translation 
and control logic but must be used with CPU. 

(2) Business Data Processing; processing business oriented data. 

BINARY CODED DECIMAL (BCD) - A form of decimal notation where decimal 
digits are represented by a binary code. 

BIT - Binary digit, either "l” or "O”. 

BLOCK - A sequential group of storage words or characters in storage. 

BOOTSTRAP - Any short program which facilitates loading of the appropriate 
system executive. 

BREAKPOINT - A point in a routine at which the computer may be stopped by 
manual switches for a visual check of progress. 

BUFFER - Any area that is used to hold data temporarily for input or output, 
normally storage. 

BYTE - A portion of a computer word, usually 6 or 12 bits. 

CAPACITY - The upper and lower limits of the numbers which may be processed 
in a register or the quantity of information which may be stored in a storage 
unit. If the capacity of a register is exceeded, an overflow is generated. 

CHANNEL - An input/output (I/O) transmission path that connects the computer 
to an external equipment; 3306 or 3307. 

CHARACTER - A group of bits which represents a digit, letter, or symbol 
from the typewriter. 

CLEAR - An operation that removes a quantity from a register by placing every 
stage of the register in the "O" state. The initial contents of the register 
are destroyed by the Clear operation. 

COMMAND - A control signal; also used synonymously with Instruction. 

COMPILER - A program with the capability to generate more than one line 
of machine code (instruction or data word) from one source language 
statement. 

COMPLEMENT - Noun: See One's Complement or Two's Complement. Verb; 

A command which produces the one's complement of a given quantity. 

CONTENT - The quantity or word held in a register or storage location. 
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CORE - A ferromagnetic toroid used as the bi-stable device for storing a bit in 
a memory plane. 

COUNTER - A register or storage location, the contents of which may be in¬ 
cremented or decremented. 

CPU - Central Processing Unit; controls all sequential operations within the 
computer. See Main Control. 

D - Delimiting indicator (refer to Delimiting). 

DELIMITING - During a BDP character operation, character delimiting may 
sometimes be used where the operation is terminated if during the course 
of the operation a character is recognized as equal (or unequal in some 
instructions) to a fixed comparison (or delimiting) character. 

DOUBLE PRECISION - Providing greater precision in the results of arithmetic 
operations by appending 24 additional bits of lesser significance to the 
initial operands. 

ENTER - The operation where the current contents of a register or storage 
location are replaced by some defined operand. 

EQUALIZE - Adjusting the operand of the algebraically smaller exponent to 

equal the larger prior to adding or subtracting the floating point coefficients. 

EXCLUSIVE OR - A logical function in Boolean algebra that is satisfied (has 
the value "l") when any of its terms are "l". It is not satisfied when all 
its terms are "l" or when all its terms are "O". 

EXECUTION ADDRESS - The lower 15 or 17 bits of a 24-bit instruction. Most 
often used to specify the storage address of an operand. Sometimes used 
as the operand. 

EXECUTIVE MODE - An operating mode in which address relocation may occur. 
An efficient operating mode consisting of two possible states; Monitor 
State and Program State. 

EXIT - Initiation of a second control sequence by the first, occurring when the 
first is near completion; the circuit involved in exiting. 

F REGISTER - Program Control register. Holds a program step while the 
single 24-bit instruction contained in it is executed. 

FAULT - Operational difficulty which lights an indicator or for which interrupt 
may be selected. 

FILE MANAGER - A software system operating in conjunction with MSIO and 
providing a central repository for all data accruing in a particular data 
center, i. e. , a system which creates a file for the user. 

FIXED POINT - A notation or system of arithmetic in which all numeric quan¬ 
tities are expressed by a predetermined number of digits with the binary 
point implicitly located at some predetermined position; contrasted with 
floating point. 


Glossary - 3 


Rev. A 



FLIP-FLOP (FF) - A bi-stable storage device. A "l" input to the set side 
puts the FF in the "l" state; a "l" input to the clear side puts the FF in 
the "O" state. The FF remains in a state indicative of its last "l” input. 

A stage of a register consists of a FF. 

FLOATING POINT - A means of expressing a number, X, by a pair of numbers, 
Y and Z, such that X = Yn^. Z is an integer called the exponent or 
characteristic; n is a base, usually 2 or 10; and Y is called the fraction or 
mantissa. 

FUNCTION CODE - See Operation Code. 

INCREASE - The increase operation adds a quantity to the contents of the 
specified register. 

INDEX DESIGNATOR - A 2-bit quantity in an instruction; usually specifies an 
index register whose contents are to be added to the execution address; 
sometimes specifies the conditions for executing the instruction. 

INDIRECT ADDRESSING - A method of address modification whereby the lower 
18 bits of the specified address become the new execution address and 
index designator. 

INSTRUCTION - A 24- or 48-bit quantity consisting of an operation code and 
several other designators. 

INTEGRATED REGISTER FILE - The upper 64io locations of core storage; re¬ 
served for special operations with Block Control. 

INTERRUPT - A signal which results in transfer of control, following comple¬ 
tion of the current instruction cycle, to a fixed storage location. 

INTERRUPT REGISTER - A 24-bit register whose individual bits are set to "l" 
by the occurrence of specific interrupt conditions, either internal or 
external. 

INTERRUPT MASK REGISTER - A 24-bit register whose individual bits match 
those of the Interrupt register. Setting bits of the Interrjpt Mask register 
to "I's” is one of the conditions for selecting interrupt. 

INVERTER - A circuit which provides as an output a signal that is opposite to 
its input. An inverter output is "l" only if all the separate OR inputs are 
" 0 ". 


ISR - Instruction State Register; 3-bit register defining the program address 
group being referenced for instructions. 

JUMP - An instruction which alters the normal sequence control of the com¬ 
puter and, conditionally or unconditionally, specifies the location of the 
next instruction. 

LIBRARY - Any collection of programs (routines) and/or subprograms 
(subroutines). 
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LOAD - The Load operation is composed of two steps: a) the register is 
cleared, and b) the contents of storage location M are copied into the 
cleared register. 

LOCATION - A storage position holding one computer word, usually designated 
by a specific address. 

LOGICAL PRODUCT - In Boolean algebra, the AND function of several terms. 
The product is "l" only when all the terms are "l”; otherwise it is "O". 
Sometimes referred to as the result of bit-by-bit multiplication. 

LOGICAL SUM - In Boolean algebra, the OR function of several terms. The 
sum is "l" when any or all of the terms are "l"; it is "O" only when all 
are "O". 

LOOP - Repetition of a group of instructions in a routine. 

MACRO CODE - A method of defining a subroutine which can be generated 
and/or inserted by the assembler. 

MAIN CONTROL - The sequence of events within the CPU controlling the 
various operations of program execution; synonomous with Program 
Control. 

MASK - In the formation of the logical product of two quantities, one quantity 
may mask the other; i.e. , determine what part of the other quantity is to 
be considered. If the mask is "0", that part of the other quantity is un¬ 
used; if the mask is "l", the other quantity is used. 

MASTER - Multiple Access, Shared Time, Executive Routine; an advanced 

time-sharing operating system for 3300 and 3500 computers equipped with 
the 3311 multiprogramming option. 

MASTER CLEAR - A general command produced by pressing one of three switche 
a) Internal Master Clear - clears all operational registers and control 
FFs in the processor; b) External Master Clear - clears all external equip¬ 
ments and the communication channels; c) Master Clear - a keyboard switch 
that performs both an Internal and External clear. 

MCS - Magnetic Core Storage; see CORE. 

MNEMONIC CODE - A three-or four-letter code which represents the function 
or purpose of an instruction. Also called alphabetic code. 

MODULUS - An integer which describes certain arithmetic characteristics of 

registers, especially counters and accumulators, within a digital computer. 
The modulus of a device is defined by r*^ for an open-ended device and r^-1 
for a closed (end-around) device, where r is the base of the number system 
used and n is the number of digit positions (stages) in the device. Generally, 
devices with modulus r'^ use two's complement arithmetic; devices with 
modulus r*^-! use one's complement. 

MONITOR STATE - An operating state under Executive mode in which all 3300 
instructions may be executed. If the 3311 Multiprogramming option is in a 
system, address relocation is possible. 
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MSIO - Mass Storage Input/Output; a basic file oriented I/O program for 
operating with mass storage devices and magnetic tape units. 

MULTI-PROCESSING- Simultaneous instruction processing; multi-processing 
is accomplished in the 3 300 by using an additional CPU. 

MULTIPROGRAMMING - Alternately servicing instructions from two or more 
programs as opposed to completing one job at a time. Multiprogramming 
utilizes the time-sharing capabilities of the computer under the guidance 
of an executive monitor. 

NON-EXECUTIVE MODE - An operating mode in which instructions are 

sequentially executed and which permits a 3300 to perform identically to a 
3200. 

NO-OP - No-Operation. 

NO-OPERATION - Usually an undefined octal code that produces no useful 

function. Some 3300 instructions are No-Operation (NO-OP) instructions 
if execution is attempted in non-Executive mode. 

NORMALIZE - To adjust the exponent and mantissa of a floating point result so 
that the mantissa lies in the prescribed standard (normal) range. 

NORMAL JUMP - An instruction that jumps from one sequence of instructions 
to a second and makes no preparation for returning to the first sequence. 
Also referred to as an unconditional jump. 

NUMERIC CODING - A system of abbreviation in which all information is re¬ 
duced to numerical quantities. Also called absolute or machine language 
coding. 

OBJECT PROGRAM - The machine language version of the source program. 

ONE'S COMPLEMENT - With reference to a binary number^ that number which 
results from subtracting each bit of a given number from "I'V The one's 
complement of a number is formed by complementing each bit of it indi¬ 
vidually, that is, changing a "l" to "O" and a "O” to a "l''. A negative 
number is expressed by the one's complement of the corresponding positive 
number. 

ON-LINE OPERATION - A type of system application in which the input or 
output data to or from the system is fed directly from or to the external 
equipment. 

OPERAND - Usually refers to the quantity specified by the execution address. 

OPERATION CODE (Function Code) - A 6-bit quantity in an instruction 
specifying the operation to be performed. 

OPERATIONAL REGISTERS - Registers which are displayed on the operator's 
section of the console. 
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OR FUNCTION - A logical function in Boolean algebra that is satisfied (has 
the value "l") when any of its terms are "l". It is not satisfied when all 
terms are "O”. Often called the inclusive OR function. 

OSR - Operand State Register; 3-bit register defining the program address group 
being referenced for operands. 

OVERFLOW - The capacity of a register is exceeded. 

P REGISTER - The Program Address Counter (P register) is a one's comple¬ 
ment additive register (modulus 21^-1) which defines the storage addresses 
containing the individual program steps. 

PAGE - 2,048 absolute memory locations which may be subdivided into four 
partial pages. Storage allocation is made in whole number multiples of 
quarter pages. 

PAGE INDEX FILE - A word-organized core matrix consisting of 12-bit page 
indexes. The contents of the page indexes are used during address 
relocation. 

PARAMETER - An operand used by a program or subroutine. 

PARITY CHECK - A summation check in which a group of binary digits 

are added and the sum checked against a previously computed parity digit; 
i.e. , a check which tests whether the number of ones is odd or even. 

PICTURE - A compact way of describing a data item. Among the things it may 
specify are size, class, sign, and editing. 

PROGRAM - A precise sequence of instructions that accomplishes the solution 
of a problem. Also called a routine. 

PROGRAM ADDRESS GROUP - A group of sequentially numbered addresses 
representing one or more programs within 32,768 words of storage. It 
is not a discrete physical device. 

PROGRAM ADDRESS REGISTER - Synonomous with P register. 

PROGRAM CONTROL - Synonomous with Main Control. 

PROGRAM STATE - A highly efficient operating state of Executive mode in 

which all 3300 instructions may be executed except those instructions that 
call for I/O operations, alter certain register file locations, or halt the 
computer. 

PROGRAM STATE NUMBER - One of seven Program Address Groups. 

PSEUDO CODE - A statement requesting a specific operation by the assembler 
or compiler. 

Q REGISTER - Auxiliary 24-bit arithmetic register which assists the A register 
in the more complicated arithmetic operations. 
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RADIX - The number of different digits that can occur in a digit position for a 
specific number system. It may be referred to as the base of a number 
system. 

RANDOM ACCESS - Access to storage under conditions in which the next 

position from which information is to be obtained can be independent of the 
previous one. 

READ - To remove a quantity from a storage location. 

REGISTER - The internal logic used for temporary storage or for holding a 
quantity during computation. 

REJECT - A signal generated under certain circumstances by either the exter¬ 
nal equipment or the processor during the execution of I/O instructions. 

RELOCATION - Making efficient use of all memory locations by reassignment 
through the use of a memory paging system under control of a monitor 
program. 

REPLACE - When used in the title of an instruction, the result of the execution 
of the instruction is stored in the location from which the initial operand was 
obtained. When replace is used in the description of an instruction, the 
contents of a location or register are substituted by the operand. The 
Replace operation implies clearing the register or portion of the register 
in preparation for the new quantity. 

REPLY - A response signal in I/O operations that indicates a positive response 
to some previous operation or request signal. 

REPORT GENERATOR - A language and compiler to reduce the programming 
necessary to generate reports. 

RETURN JUMP - An instruction that jumps from a sequence of instructions to 
initiate a second sequence and prepares for continuing the first sequence 
after the second is completed. 

ROUTINE - The sequence of operations which the computer performs, also 
called a program. 

S REGISTER - The 13-bit S register displays the address of the storage word 
currently being referenced. 

SCALE FACTOR - One or more coefficients by which quantities are multiplied 
or divided so that they lie in a given range of magnitude. 

SCAN - Synonomous with Search. 

SEARCH - Searching a field of characters for a certain condition or a specific 
character. 

SHIFT - To move the bits of a quantity right or left. 
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SIGN BIT - In registers where a quantity is treated as signed by use of one's 
complement notation, the bit in the highest order stage of the register. If 
the bit is "l", the quantity is negative; if the bit is "O”, the quantity is 
positive. 

SIGN CHARACTER - A unique character that indicates the algebraic sign (positive 
or negative) of a given field of characters. The upper two bits of a normal 
6-bit character may be used or in some instances a specially formed 4-bit 
character exits. 

SIGN EXTENSION - The duplication of the sign bit in the higher order stages of 
a register. 

SOFTWARE - Programs and/or subroutines. 

SOURCE LANGUAGE - The language used by the programmer to define his 
program. 

STAGE - The FFs and inverters associated with a bit position of a register. 

STATUS - The state or condition of circuits within the processor, I/O channels, 
or external equipment. 

STORAGE CONTROL - The sequence of events within a particular storage 
module, controlling various internal storage operations. 

STORE - To transmit information to a device from which the unaltered infor¬ 
mation can later be obtained. The Store operation is essentially the re¬ 
verse of the Load operation. Storage location M is cleared, and the con¬ 
tents of the register are copied into M. 

SUBROUTINE - A set of instructions that is used at more than one point in 
program operation. 

SYMBOLIC CODING - A system of abbreviation used in preparing information 
for input into a computer; e.g. , Shift Q would be SHQ. (See Mnemonic) 

TOGGLE - To complement each specified bit of a quantity; i.e. , "l” to "O” or 
"0" to "1". 

TRANSMIT (Transfer) - The term transfer implies register contents are 

moved; i.e. , the contents of register 1 are copied into register 2. Unless 
specifically stated, the contents are not changed during transmission. The 
term transmit is often used synonymously with transfer. 

TWO'S COMPLEMENT - Number that results from subtracting each bit of a 

number from "O". The two's complement may be formed by complementing 
each bit of the given number and then adding one to the result, performing 
the required carries. 

UNDERFLOW - An illegal change of sign from - to +, e.g. , subtracting from a 
quantity so that the result would be less than - (2’^-l), where n is the 
modulus. In floating point notation, this occurs where the value of the 
exponent becomes less than 2~10 + 1 (- 1777g). 
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WORD - The content of a storage location; it can be an instruction or 24 bits of 
data. 

WRITE - To enter a quantity into a storage location. 

X REGISTER - An arithmetic transfer register, nonaddressable and not 
displayed. 

Z REGISTER - A 28-bit storage data register; receives the data and parity bits 
as they are read from storage or written into storage. Nonaddressable but 
displayed on the 'T' panel in the storage module. 
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TABLE 1. OCTAL LISTING OF INSTRUCTIONS 


Basic 

Octal 

Code 

Mnemonic 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

00 

HLT 

m 

Unconditional halt, RNl @ m on restarting 

5-24 

00 

SJl 

m 

If jump key 1 is set, jump to m 

5-41 

00 

SJ2 

m 

If jump key 2 is set, jump to m 

5-41 

00 

SJ3 

m 

If jump key 3 is set, jump to m 

5-41 

00 

SJ4 

m 

If jump key 4 is set, jump to m 

5-41 

00 

SJ5 

m 

If jump key 5 is set, jump to m 

5-41 

00 

SJ6 

m 

If jump key 6 is set, jump to m 

5-41 

00 

RTJ 

m 

P+1 -»-m (address portion),RNI @ m+1, 
return to m for P+1 

5-47 


UJPJ 

m ,b 

Unconditional jump to m 

5-41 

mm 

No Operation 



02 

IJI 

m,b 

If (B^) = 0,RNI @ P+1; if (B^) 0, (b’^) + 

1 -*Bb, RNI @ m 

5-43 

02 

No Operation 

If (B*^) = 0, RNI @ P+1; if (B^) f 0, (B^) - 
1 -Bb, RNI @ m 


02 

IJD 

m,b 

5-44 

03 

AZJ,EQ 

m 

If (A) = 0,RNI @ m, otherwise RNI @ P+1 

5-45 

03 

AZJ.NE 

m 

If (A) f 0,RNI @ m, otherwise RNI @ P+1 

5-45 

03 

AZJ^GE 

m 

If (A) >0, RNI® m, otherwise RNI @ P+1 

5-45 

03 

AZJ,LT 

m 

If (A) <0, RNI@m, otherwise RNI @ P+1 

5-45 

03 

AQJ,EQ 

m 

If (A) = (Q),RNI @ m, otherwise RNI @ P+1 

5-46 

03 

AQJ,NE 

m 

If (A) f (Q),RNI @ m,otherwise RNI® P+1 

5-46 

03 

AQJ.GE 

m 

If (A) >(Q),RNI ® m,otherwise RNI@P+1 

5-46 

03 

AQJ.LT 

m 

If (A) <(Q),RNI ® m,otherwise RNI® P+1 

5-46 

04 

ISE 

y 

If y = 0,RNI ® P+2, otherwise RNI @ P+1 

5-28 

04 

ISE 

y»b 

If y = (B^),RNI @ P+2,otherwise RNI ® P+1 

5-28 

04 

ASE,S 

y 

If y = (A), RNI @ P + 2, otherwise RNI ® 

P + 1. Sign of y extended. 

5-29 

04 

QSE,S 

y 

If y = (Q)> RNI ® P + 2, otherwise RNI ® 

P + 1. Sign of y extended. 

5-29 

04 

ASE 

y 

If y = (A), RNI @ P + 2, otherwise RNI @ 

P + 1. Lower 15 bits of A are used. 

5-29 

04 

QSE 

y 

If y = (Q), RNI @ P + 2, otherwise RNI @ 

P + 1. Lower 15 bits of Q are used. 

5-29 
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TABLE 1. OCTAL LISTING OF INSTRUCTIONS (Cont'd) 


Basic 

Octal 

Code 

Mnemonic 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

05 

ISG 

y 

If y = 0, RNI @ P+2, otherwise RNI @P+1 

5-30 

05 

ISG 

y.b 

(Bb) >y, RNI @ P+2, otherwise RNI @ P+1 

5-30 

05 

ASG,S 

y 

If (A) >y, RNI @ P+2, otherwise RNI @ 
P+1. Sign of y is extended 

5-30 

05 

QSG,S 

y 

If (Q) >y, RNI @ P+2, otherwise RNI @ 
P+1. Sign of y is extended 

5-30 

05 

ASG 

y 

If (A) >y, RNI @ P+2, otherwise RNI @ P+1 

5-30 

05 

QSG 

y 

If (Q)>y.RNI @ P+2, otherwise RNI @ P+1 

5-30 

06 

MEQ 

m,i 

(pf) - i if (pI) negative,RNI @P+1; 

if (B^) positive,test (A) = (Q) A (M); if 
true, RNI @ P+2; if false, repeat sequence 

5-75 

07 

MTH 

m, i 

(B2)-i'^2. if negative RNI @ P+1; if 

(B^) positive, test (A) >(Q) A (M); if true, 
RNI @ P+2; if false, repeat sequence 

5-76 

10 

SSH 

m 

^Test sign of (m), shift left one place, end 
around, replace in storage. If sign neg¬ 
ative, RNI @P+2; otherwise RNI @ P+1 

5-57 

10 

ISI 

y.b 

If (b’^)= y, clear pb and RNI @ P+2; if 
(Pb) f y, (pb) + 1 -i^pb, RNI @ P+1 

5-31 

10 

ISD 

y.b 

If {P^) = y, clear P^ and RNI @ P+2; if 
(pb) y, (pb) - 1 -»Bb, RNI @ P+1 

5-31 

in 

ECHA 

Z 

z '♦A, lower 17 bits of A are used 

5-26 

n 

ECHA,S 

z 

z A, sign of z extended 

5-26 

12 

SHA 

k, b 

Shift (A). Shift count K=k+(B^) (signs of k 
and pb extended. )If bit 23 of K="l", shift 
right; complement of lower 6 bits equals 
shift magnitude. If bit 23 of K=''0'', shift 
left; lower 6 bits equals shift magnitude. 
Left shifts end around;right shifts end off. 

5-57 

12 

SHQ 

k, b 

Shift (Q). Shift count K=k+(Bb)(signs of k 
and pb extended. If bit 23 of K=''l", shift 
right;complement of lower 6 bits equals 
shift magnitude. If bit 23 of K="0'', shift 
left;lower 6 bits equals shift magnitude. 
Left shifts end around;right shifts end off. 

5-59 

13 

SHAQ 

k, b 

Shift (AQ) as one register. Shift count K= 
k+(Bb) (signs of k and pb extended). If 
bit 23 of K="l", shift right;complement of 
lower 6 bits equals shift magnitude.If bit 

23 of K="0", shift left;lower 6 bits equal 
shift magnitude. Left shifts end around; 
right shifts end off. 

5-59 
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TABLE 1. OCTAL LISTING OF INSTRUCTIONS (Cont’d) 


Basic 

Octal 

Code 

Mnemonic 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

13 

SCAQ 

k, b 

Shift (AQ) left end around until upper 2 bits 
of A are unequal. Residue K = k - shift 
count. Ifb = 1,2, or 3, K-*" B^; if b = 0, K 
is discarded. 

5-59 

14 

No Operation 

No operation (COMPASS assembled NOP) 


14 

ENI 


Clear B^, enter y 

5-25 

14 

ENA,S 

y 

Clear A, enter y, sign,of y extended 

5-25 

14 

ENQ,S 

y 

Clear Q, enter y, sign of y extended 

5-25 


ENA 

y 

Clear A, enter y 

5-25 

1 

ENQ y 

No Operation 

Clear Q, enter y 

5-25 

15 

INI 

y>b 

Increase (B^) by y, signs of y and 
extended 

5-27 

15 

INA,S 

y 

Increase (A) by y, sign of y extended 

5-27 

15 

INQ,S 

y 

Increase (Q) by y, sign of y extended 

5-27 

15 

INA 

y 

Increase (A) by y 

5-27 

15 

16 

INQ y 

No Operation 

Increase (Q) by y 

5-27 

16 

XOI 

y.b 

y V (B*^) -B^ 

5-71 

16 

XOA,S 

y 

y V (A) -*A, sign of y extended 

5-71 

16 

XOQ,S 

y 

y V (Q) -»'Q, sign of y extended 

5-71 

16 

XOA 

y 

y V (A) -> A 

5-71 

16 

17 

XOQ y 

No Operation 

y V (Q) -^Q 

5-71 

17 

ANI 

y,b 

y A (B*^) -B^ 

5-73 

17 

ANA,S 

y 

y A (A) ^A, sign of y extended 

5-73 

17 

ANQ,S 

y 

y A (Q) ^Q, sign of y extended 

5-74 

17 

ANA 

y 

y A (A) ^A 

5-73 

17 

ANQ 

y 

y A (Q) 

5-74 

20 

LDAM 

m,b 

(M) -^A 

5-49 

21 

LDQ,I 

m ,b 

(M) 

5-51 

22 

LACK 

r, 1 

(R) ~*A. Load lower 6 bits of A 

5-49 

23 

LQCH 

r,2 

(R) -^Q. Load lower 6 bits of Q 

5-52 
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TABLE 1. OCTAL LISTING OF INSTRUCTIONS (Cont'd) 


Basic 

Octal 

Code 

Mnemonic 

Code 

Addre ss 
Field 

Instruction Description 

Page I 
No. 

24 

,LCA,I 

m,b 

(M) -*A 

5-50 

25 

LDAQ,I 

m, b 

(M) -A, (M + 1) -Q 

5-50 

26 

LCAQM 

m,b 

(M) ->A, (M + 1) -^Q 

5-51 

27 

LDL,I 

m,b 

(M) A (Q) -A 

5-50 

30 

ADA, I 

m, b 

Add (M) to (A) ->A 

5-60 

31 

SBA,I 

m, b 

(A) minus (M) -*A 

5-61 

32 

ADAQ,I 

m, b 

Add (M,M + 1) to (AQ) -^AQ 

5-61 

33 

SBAQ,I 

m,b 

(AQ) minus (M,M + 1 ) -*AQ 

5-61 

34 

RAD, I 

m,b 

Add (M) to (A) -»-(M) 

5-60 

35 

SSA,I 

m,b 

Where (M) contains a "l" bit, set the cor¬ 
responding bit in A to "l" 

5-72 

36 

SCA,I 

m, b 

Where (M) contains a "l" bit, complement 
the corresponding bit in A 

5-72 

37 

LPA,I 

m, b 

(M) A (A) ->A 

5-73 

40 

STA,I 

m, b 

(A) -^(M) 

5-53 

41 

STQ,I 

m, b 

(Q) -^(M) 

5-55 

42 

SACK 

r ,2 

(AoO-05) -*-R 

5-54 

43 

SQCH 

r, 1 

(QOO-05) -^R 

5-55 

44 

SWA, I 

m, b 

(AOO-14) -*(M00-14) 

5-56 

45 

STAQ,I 

m, b 

(AQ) '-(M,M + 1) 

5-54 

46 

SCHA,I 

m,b 

(Aoo- 16) ^(Moo-io) 

5-56 

47 

STI,I 

m,b 

(B^) (Moo-14) 

5-56 

50 

MUA,I 

m,b 

Multiply (A) by (M) -*-QA; lowest order bits 
of product in A 

5-62 

51 

DVA,I 

m, b 

(AQ)- 5 - (M) a, remainder ^ Q 

5-62 

52 

CPR,I 

m,b 

(M) >(A), RNI @ P+1 1 ^ (Qx 

(Q)>(M), RNI@P+2 KtchSiged 

(A) >(M) > (Q), RNI @ P+3j uncnangea 

5-77 

53 

TIA 

b 

Clear (A),(B^-^ Aoo -14 

5-33 

53 

TAI 

b 

(AoO-14)~^ 

5-33 

53 

TMQ 

V 

(v) -*Q 

5-34 

53 

TQM 

V 

(Q) -^v 

5-34 

53 

TMA 

V 

(v) - A 

5-34 

53 

TAM 

V 

(A) -*v 

5-34 
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TABLE 1. OCTAL LISTING OF INSTRUCTIONS (Cont'd) 


Basic 

Octal 

Code 

Mnemonic 

Code 

Address 

Field 

Instruction Description 

Page 

Na. 

53 

TMI 

v,b 

(Voo-14) 

5-35 

53 

TIM 

v,b 

(B^) voo-14 

5-35 

53 

AQA 


Add (A) to (Q) -’■A 

5-32 

53 

AIA 

b 

Add (A) to (B^*) ^A 

5-33 

53 

lAI 

b 

Add <A) to (B^) -’-b'^. Sign of B^ extended 
prior to addition 

5-33 




All other combinations of 53 are undefined 
and will be rejected by the assembler 


54 

LDI,I 

m,b 

(Moo- 14 ) 

5-52 

55 

1 

RIS 


Use (ISR) in address relocation for 
operands. RELOCATE TO INSTRUCTION 
STATE 

5-112 

55 

ELQ 


(Ej^) -^Q 

5-36 

55 

EUA 


(Ey) -A 

5-36 

55 

EAQ 


(EuEl) -AQ 

5-36 

55 

ROS 


Use (OSR) in address relocation for 
operands. RELOCATE TO OPERAND 
STATE 

5-112 

55 

QEL 


(Q)-El 

5-36 

55 

AEU 


(A) -Ey 

5-36 

55 

AQE 


(AQ) -EyEL 

5-36 

56 

MUAQ,I 

m, b 

Multiply (AQ) by (M,M + 1) -^-AQE 

5-63 

57 

DVAQ,I 

m, b 

(AQE)-r (M,M + 1) ^AQ and remainder 
with sign extended to E. Divide fault halts 
operation and program advances to next 
instruction 

5-63 

60 

FAD, I 

m, b 

Floating point addition of (M,M + 1) to 
(AQ) --AQ 

5-65 

61 

FSB, I 

m, b 

Floatingpoint subtraction of (M,M + 1) 
from (AQ) -*AQ 

5-65 

62 

FMU,I 

m, b 

Floating point multiplication of (AQ) and 
(M,M + 1) -*AQ 

5-66 

63 

FDV,I 

m,b 

Floating point division of (AQ) by (M, M 
+ 1) -^AQ, remainder with sign extended 
to E 

5-66 

64 

MVE 

^ > 

^ 1 j ® j 

Bs. S2 

Move characters from fid A -*-fld C ac¬ 
cording to parameters given 

5-140 
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TABLE 1. OCTAL LISTING OF INSTRUCTIONS (Cont'd) 


Basic 

Octal 

Code 

Mnemonic 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

64 

MVE,DC 

s,Bs, 

Move characters from fid A -^fld C 
according to parameters given. Delimiting 
character possibility 

5-141 

64 

MVBF 

r , Bj. , 

Si, S, 

Bs. S2 

Move characters from fid A ^fld C; if 
fid C >fld A, blank fill 

5-142 

64 

MVZF 

r, Bj,, 

Si, s, 
Bs. S2 

Move characters from fid A ^fld C; if 
fid C >fld A, zero fill 

5-143 

64 

MVZS 

r, Bjp, 
Si, s, 
Bs, S 2 

Move characters from fid A ^fld C; sup¬ 
press leading zeros 

5-144 

64 

MVZS,DC 

r, B , 

s, Bg, 

S 2 

Move characters from fid A -^fld C; sup¬ 
press leading zeros. Delimiting character 
possibility 

5-145 

64 

EDIT 

r. Bp, 

Si, s, 
Bs. S 2 

Fid A -»fld C with COBOL type of editing 
specified by picture previously stored in 
fid C 

5-149 

64 

FRMT 

r* B 

X j > 

Si, s, 

Bs , S 2 

Fid A fid C with editing specified by 

picture previously stored in fid; limited 
to specific types of editing to allow pro¬ 
cessing in a single scan. 

5-147 

65 

SCAN, 

LR,EQ 

r, Bj,, 

S 2 . SC 

Scans fid A from left to right, stop on = 
condition 

5-129 

65 

SCAN, 
LR, EQ, 
DC 

r, Br, 

S 2 . SC 

Scans fid A from left to right, stop on = 
condition. Delimiting character possibility 

5-130 

65 

SCAN, 

RL,EQ 

r, Br, 

S 2 , SC 

Scans fid A from right to left, stop on = 
condition 

5-133 

65 

SCAN, 
RL, EQ, 
DC 

r, Br, 

S2, SC 

Scans fid A from right to left, stop on = 
condition. Delimiting character 
possibility 

5-134 

65 

SCAN, 

LR,NE 

r, Bj,, 

S 2 . SC 

Scans fid A from left to right, stop on 4 
condition 

5-131 

65 

SCAN, 
LR, NE 
DC 

r.B , 
S 2 .SC, 

Scan fid A from left to right, stop on / 
condition. Delimiting character possibility 

5-132 

65 

SCAN, 

RL, NE 

r > Br , 
S 2 .SC 

Scans fid A from right to left, stop on / 
condition 

5-135 
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Basic 

Octal 

Code 

Mnemonic 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

65 

SCAN, RL, 

r,Bj., 

Scans fid A from right to left, stop on 4^ 



NE.DC 

S2,SC, 

condition. Delimiting character possibility 

5-136 

66 

CVDB 

r, B^, 

Si, m, 
Bm 

Convert BCD fid A to binary fid ^C 

5-115 

66 

CVBD 

m, Bj;n> 

n. Bn 

Convert binary fid A to BCD ^fld C 

5-116 

66 

DTA 

r, Br, 
S2. m, 
Bm 

Translate BCD fid A to ASCR - fid C 

5-117 

66 

DTA,DC 

r, Bj., 

S2 .m, 
Bm 

Translate BCD fid A to ASCII - fid C with 
delimiting character possibility 

5-118 

66 

ATD 

m, Bnn,, 
S2, s, 
Bs 

Translate ASCII fid A to BCD - fid C 

5-119 

66 

ATD,DC 

m, Bm. 
S2 > s, 
Bs 

Translate ASCII fid A to BCD - fid C with 
delimiting character possibility 

5-120 

66 

PAK 

r. Bp 

S2. m, 

Pack 6-bit BCD fid A into 4-bit BCD fid C 

5-121 

66 

UPAK 

s, Bs, 

S2 

Unpack 4-bit BCD fid A into 6-bit BCD fid C 

5-122 

67 

ADM 

r. Bp, 
Si, s, 
Bs^ ^2 

Add fid A to fid C - fid C 

5-68 

67 

SBM 

r, Br, 
Si, s, 
Bs^ ^2 

Subtract fid A from fid C — fid C 

5-69 

67 

1 

ZADM 

r. Bp, 
Si, s, 
Bs. ^2 

Clear fid C; fid A - fid C, right justify 

5-146 
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Basic 

Octal 

Code 

Mnemonic 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

67 

CMP 

r, Br, 
Srs, 

®s'S2 

Compares fid A to fid C, exits upon 
encountering ^ characters 

5-79 

67 

CMP, DC 

r, Bj., 

s, Bg, 

^2 

Compares fid A to fid C, exits upon en¬ 
countering 4 characters; delimiting 
character possibility 

5-80 

67 

TST 

r, Br, 

Si 

r, Bj,, 

Si 

m 

Test fid A, +, -, or 0 

5-82 

67 

TSTN 

Test fid A for numeric 

5-82. 0 

70 

JMP, HI 

Jump if BDP condition register > 0 or + 

5-42 

70 

JMP, ZRO 

m 

Jump if BDP condition register = 0 

5-42 

70 

JMP, LOW 

m 

Jump if BDP condition register < 0 or - 

5-42 

70 

LBR 

m 

Load BCR and restore BDP conditions 
from data at 'm' 

5-155 

70 

SBR 

m 

Store (BCR) and BDP conditions at 'm' 
for interrupt recovery. 

5-155 

71 

SRCE, 

INT 

sc, r, s 

Search for equality of scan character 
'SC^ in a field beginning at location r 
until an equal character is found, or 
until character location s is reached; 

5-125 

71 

SRCN, 

INT 

SC, r, s 

Same as SRCE except search condition is 
for inequality 

5-127 

72 

MOVE, 

INT 

S, r, s 

Move (S) characters from r to s 

5-138 

73 

INPC, INT 
B, H, G 

ch, r, s 

A 6- or 12-bit character is read from 
peripheral device and stored in memory 
at a given location 

5-98 

73 

INAC, 

INT 

ch 

(A) is cleared and a 6-bit character is 
transferred from a peripheral device to 
the lower 6 bits of A 

5-106 

74 

INPW, 

INT, B, N, 
G 

ch, m, 
n 

Word address is placed in bits 00-14, 

12- or 24-bit words are read from a 
peripheral device and stored in memory 

5-100 
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Basic 

Octal 

Code 

Mnemonic 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

74 

INAW, 

INT 

ch 

(A) is cleared and a 12-or 24-bit word is 
read from a peripheral device into the lower 
12 bits or all of A (word size depends on 

I/O channel) 

5-107 

75 

OUTC, 

INT, B, H 

ch,r,s 

Storage words disassembled into 6- or 12- 
bit characters and sent to a peripheral 
device 

5-102 

75 

OTAC, 

INT 

ch 

Character from lower 6 bits of A is sent to 
a peripheral device,(A) retained 

5-109 

76 

OUTW, 

INT,B,N 

ch, m, n 

Words read from storage to a peripheral 
device 

5-104 

76 

OTAW, 

INT 

ch 

Word from lower 12 bits or all of A (de¬ 
pending on type of I/O channel) sent to a 
peripheral device 

5-110 

77 

CON 

X, ch 

If channel ch is busy, reject instruction 

RNI @ P + 1. If channel ch is not busy, 12- 
bit connect code sent on channel ch with 
connect enable, RNI @ P + 2 

5-95 

77 

SEL 

X, ch 

If channel ch is busy, read reject instructionj 
from P + 1. If channel ch is not busy, a 
12-bit function code is sent on channel ch 
with a function enable, RNI @ P + 2 

5-96 

77 

EXS 

X, ch 

Sense external status if "l" bits occur on 
status lines in any of the same positions as 
"l" bits in the mask, RNI @ P + 1. If no 
comparison, RNI @ P + 2 

5-83 

77 

COPY 

ch 

External status code from I/O channel ch -»■ 
lower 12 bits of A, contents of interrupt 
mask register -*upper 12 bits of A; RNI @ 

P + 1 

5-83 

77 

INS 

X, ch 

Sense internal status if "l" bits occur on 
status lines in any of the same positions as 
"l" bits in the mask, RNI @ P + 1. If no 
comparison, RNI @ P + 2 

5-85 

77 

Cl NS 

ch 

Interrupt mask and internal status to A 

5-86 

77 

INTS 

X, ch 

Sense for interrupt condition: If "l" bits 
occur simultaneously in interrupt lines and 
in the interrupt mask, RNI @ P + 1; if not, 
RNI @ P + 2 

5-84 

77 

INCL 

X 

Interrupt faults defined by x are cleared 

5-89 
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Octal 

Code 

Mnemonic 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

77 

lOCL 

X 

Clears I/O channel or search/move control 
as defined by bits 00-07, 08, and 11 of x. 

5-94 

77 

CILO 

X 

Lockout external interrupt on masked 
channels (x), until channel(s) is not busy. 

5-91 

77 

CLCA 

X 

Clear the specified channel, but not external 
equipment. CLEAR CHANNEL ACTIVITY 

5-94 

77 

SSIM 

X 

Selectively set interrupt mask register for 
each "l” bit in x. The corresponding bit 
in the mask register is set to "l" 

5-90 

77 

SCIM 

X 

Selectively clear interrupt mask register 
for each "l" bit in x. The corresponding 
bit in the mask register is set to "O” 

5-90 

77 

ACI 


Aoo -02 cm 

A TO CHANNEL INDEX REGISTER 

5-38 

77 

CIA 


Clear A; Channel index register -*Aqq_q 2 

5-38 

77 

JAA 


Last executed jump address A 

JUMP ADDRESS TO A 

5-40 

77 

LAPR 


Interrupt associated processor 

5-113; 

77 

PAUS 

X 

Sense busy lines. If "l" appears on a line 
corresponding to "l” bits in x, do not ad¬ 
vance P. If P is inhibited for longer than 

40 ms, read reject instruction from P + 1. 

If no comparison, RNI @ P + 2 

5-87 

77 

PRP 


Same as PAUS except real-time 
clock cannot increment during the pause 
PRIORITY PAUSE 

5-88 

77 

• TMAV 


Initiate memory request. If reply occurs 
within 5 usee, RNI @ P + 2; if not, RNI @ 

P + 1. Storage address is (B^) with (OSR) 
or zero appended.TEST MEMORY 
AVAILABILITY 

5-81 

77 

SBJP 


Transfers system from Monitor State to 
Program State when next jump instruction 
is executed. SET BOUNDARY JUMP 

5-112 

77 

SDL 


Causes next LDA instruction to: 

1. (M) -*A 

2. Store 77777777 @ M 

SET DESTRUCTIVE LOAD 

5-113 ^ 

77 

CRA 


Clear A; Condition register-^ Aoq_q 5 

5-40 , 

77 

ACR 


Aqo-OS Condition register 

o 

J 
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Octal 

Code 

Mnemonic 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

77 

APF 

w, 2 

Aoo_ii to page file 

A TO PAGE FILE 

5-39 

77 

PFA 

w, 2 

Clear A, page file index -*’A„„ ^ ^ 

PAGE FILE TO A uu iJ. 

5-39 

77 

AOS 


"^00-02 “^OSR 

A TO OPERAND STATE REGISTER 

5-37 

77 

AIS 


"^00-02 

A TO INSTRUCTION STATE REGISTER 

5-37 

77 

OSA 


Clear A; OSR 

OPERAND STATE REGISTER TO A 

5-37 

77 

ISA 


Clear A; ISR ■*-^{)o-o2 

INSTRUCTION STATE REGISTER TO A 

5-37 

77 

SLS 


Program stops if Selective Stop switch is 
on; upon restarting, RNI @ P + 1 

5-24 

77 

SFPF 


Set floating point fault logic 

5-91 

77 

SB CD 


Set BCD fault logic 

5-91 

77 

DINT 


Disables interrupt control 

5-89 

77 

EINT 


Interrupt control is enabled, allows one more 
instruction to be executed before interrupt 

5-89 

77 

77 

CTI 

CTO 


Set Type In 

Set Type Out 

Beginning character address 
must be preset in location 23 
, of register file and last 
character address + 1 must 
be preset in location 33 of 
the file 

5-97 

77 

ucs 


Unconditional stop. Upon restarting, RNI 
@ P + 1 

5-24 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS 


Mnemonic 

Basic 

Address 

Instruction Description 

Page 

Code 

Octal 

Code 

Field 


No. 

AC I 

77 


^00-02 

A TO CHANNEL INDEX REGISTER 

5-38 

ACR 

77 


Aoo_o 5 Condition register 

5-40 

ADA, I 

30 

m, b 

Add (M) to (A)-^ a 

5-60 

ADAQ, I 

32 

m, b 

Add (M, M + 1) to (AQ) AQ 

5-61 

ADM 

67 

Br* SIj 
s, Bg, S 2 

Add fid A to fid C - fid C 

5-68 

AEU 

55 


(A) - E^ 

5-36 

AIA 

53 

b 

Add (A) to (Bb) ->A 

5-33 

AIS 

77 


^00-02 "^ISR 

A TO INSTRUCTION STATE REGISTER 

5-3 7 

ANA 

17 

y 

y A (A) -^A 

5-73 

ANA,S 

17 

y 

y A (A) -^A, sign of y extended 

5-73 

ANI 

17 

y>ti 

y A (Bb) -*Bb 

5-73 

ANQ 

17 

y 

y A (Q) 

5-74 

ANQ,S 

17 

y 

y A (Q) -*Q, sign of y extended 

5-74 

AOS 

77 


AoO-02 -*0SR 

A TO OPERAND STATE REGISTER 

5-37 

APF 

77 

w, 2 

“^00-11 -^Page file 

A TO PAGE FILE 

5-39 

AQA 

53 


Add (A) to (Q) -A 

5-32 

AQE 

55 


(AQ) -^EuEl 

5-36 

AQJ,EQ 

03 

m 

If (A) = (Q), RNI @ m, otherwise RNI @ 

P + 1 

5-46 

AQJ,GE 

03 

m 

If (A) XQ), RNI @ m, otherwise RNI @ 




P + 1 

5-46 

AQJ, LT 

03 

m 

If (A) <(Q), RNI @ m, otherwise RNI @ 

P + 1 

5-46 

AQJ,NE 

03 

m 

If (A) ^ (Q), RNI @ m, otherwise RNI @ 

P + 1 

5-46 

ASE 

04 

y 

If y = (A), RNI @ P + 2, otherwise RNI @ 

P + 1. Lower 15 bits of A are used. 

5-29 

ASE,S 

04 

y 

If y = (A), RNI @ P + 2, otherwise RNI @ 

P + 1, sign of y is extended 

5-29 

ASG 

05 

y 

If (A) >y, RNI @ P + 2, otherwise RNI @ 

P + 1 

5-30 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont'd) 


Mnemonic 

Code 

— 

Basic 

Octal 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

ASG.S 

05 

y 

If (A) >y, RNI @ P + 2, otherwise RNI @ 

P + 1, sign of y is extended 

5-30 

ATD 

66 

mBm. 

^2’ 

Bs 

Translate ASCII fid A to BCD -> fid C 

5-119 

ATD.DC 

66 

$2^ s, 

B=, 

Translate ASCII fid to BCD ->fld C with 
delimiting character possibility 

5-120 

AZJ,EQ 

03 

m 

If (A) = 0, RNI @ m, otherwise RNI @ 

P + 1 

5-45 

AZJ,GE 

03 

m 

If (A) >0, RNI @ m, otherwise RNI @ 

P + 1 

5-45 

AZJ,LT 

03 

m 

If (A) <0, RNI @ m, otherwise RNI @ 

P + 1 

5-45 

AZJ, NE 

03 

m 

If (A) f 0, RNI @ m, otherwise RNI @ 

P + 1 

5-45 

CIA 

77 


Clear A; Channel index register *^Aqq_q 2 

5-38 

CILO 

77 

X 

Lockout external interrupt on masked 
channels (x), until channel(s) is not busy 

5-91 

CINS 

77 

ch 

Interrupt mask and internal status to A 

5-86 

CLCA 

77 

X 

Clear the specified channel, but not ex¬ 
ternal equipment. CLEAR CHANNEL 
ACTIVITY 

5-94 

CMP 

67 

r,Bp, 

Si, s, 
Bs, S2 

Compares fid A to fid C, exits upon en¬ 
countering ^ characters 

5-79 

CMP, DC 

67 

r, B^., 

s, Bs 

S2 

Compares fid A to fid C, exits upon en¬ 
countering ^ characters; delimiting 
character possibility 

5-80 

CON 

77 

X, ch 

If channel ch is busy, reject instruction, 
RNI @ P+1. If channel ch is not busy, 

12-bit connect code sent on channel ch 
with connect enable, RNI @ P+2. 

5-95 

COPY 

77 

ch 

External status code from I/O channel ch 
to lower 12-bits of A, contents of inter¬ 
rupt mask register to upper 12-bits of 

A RNI @ P+1 

5-83 

CPR,I 

52 

m,b 

(M) >(A), RNI @ P+1 T (A) and (Q) 

(Q) > (M), RNI @ P + 2 kre 

(A) >.(M) >(Q), RNI @ P+3j unchanged 

5-77 

CRA 

77 


Condition register to Aqo-05 

5-40 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont'd) 



Page 

No. 


5-97 

5-116 

5-115 

5-89 

5-117 


5-118 

5-62 


5-63 

5-36 

5-26 

5-26 

5-149 

5-89 

5-36 

5-25 

5-25 

5-25 

5-25 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont'd) 


Mnemonic 

Code 

Basic 

Octal 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

ENQ,S 

14 

y 

Clear Q, enter y, sign of y extended 

5-25 

EUA 

55 


(Ey) - A 

5-36 

EXS 

77 

X, ch 

Sense external status if "l" bits occur on 
status lines in any of the same positions 
as "l" bits in the mask, RNI @ P+1. If 
no comparison RNI @ P+2. 

5-83 

FAD, I 

60 

m,b 

Floating point addition of (M,M + 1) to 
(AQ) “^AQ 

5-65 

FDV,I 

63 

m, b 

Floating point division of (AQ) by (M,M + 

1) '►AQ, Remainder with sign extended to 

E. 

5-66 

FMU,I 

62 

m,b 

Floating point multiplication of (AQ) and 
(M,M + 1) -^AQ 

5-66 

FRMT 

64 

r,Br, 

Si,s, 

Fid A -*■ fid C with editing specified by 
picture previously stored in fid; limited to 
specific types of editing to allow pro¬ 
cessing in a single scan. 

5-147 

FSB, I 

61 

m, b 

Floatingpoint subtraction of (M,M +1) 
from (AQ) -►AQ 

5-65 

HLT 

00 

m 

Unconditional halt, RNI @ m upon re¬ 
starting 

5-24 

LAI 

53 

b 

Add (A) to (B^) -*• B^. Sign of b'^ extended 
prior to addition 

5-33 

lAPR 

77 


Interrupt associated processor 

5-113 

IJD 

02 

m,b 

If (B*^) = 0, RNI @ P + 1; if (b’^) f 0, (b’^) 

- 1 -BD, RNI @ m 

5-44 

IJI 

02 

m,b 

If (B^) = 0, RNI @ P + 1; if (B^) f 0, (b’^) 

+ 1 -B°. RNI @ m 

5-43 

INA 

15 

y 

Increase (A) by y 

5-27 

INA,S 

15 

y 

Increase (A) by y, sign of y extended 

5-27 

INAC, 

INT 

73 

ch 

(A) is cleared and a 6-bit character is 
transferred from a peripheral device to 
the lower 6 bits of A 

5-106 

INAW, 

INT 

74 

ch 

(A) is cleared and a 12- or 24-bit word is 
read from a peripheral device into the 
lower 12 bits or all of A (word size depends 
on I/O channel) 

5-107 

INCL 

77 

X 

Interrupt faults defined by x are cleared 

5-89 

INI 

15 

y,b 

Increase (B^) by y, signs of y and b'^ 
extended 

5-27 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont'd) 


Mnemonic 

Code 

Basic 

Octal 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

’INPC, 

INT , B , 
H,G 

73 

chj r , s 

A 6- or 12-bit character is read from a 
peripheral device and stored in memory 
at a given location 

5-98 

INPW, 

INT , B , 
N,G 

74 

ch,in, 

n 

Word Address is placed in bits 00-14, 12- 
or 24-bit words are read from a peri¬ 
pheral device and stored in memory 

5-100 

INQ 

15 

y 

Increase (Q) by y 

5-27 

INQ,S 

15 

y 

Increase (Q) by y, sign of y extended 

5-27 

INS 

77 

X j ch 

Sense internal status if "l" bits occur on 
status lines in any of the same positions 
as "l" bits in the mask, RNI @ P + 1. 

If no comparison, RNI @ P + 2 

5-85 

INTS 

77 

c , ch 

Sense for interrupt condition; if "l” bits 
occur simultaneously in interrupt lines 
and in the interrupt mask, RNI @ P + 1; 
if not, RNI @ P + 2 

5-84 

lOCL 

77 

X 

Clears I/O channel or search/move con¬ 
trol as defined by bits 00-07, 08, and 11 
of X. 

5-94 

ISA 

77 


Clear A, ISR “*Aoo-02 

INSTRUCTION STATE REGISTER TO A 

5-37 

ISD 

10 

y,b 

If (Bb) = y, clear B^ and RNI @ P + 2; 
if (Bb) f y, (Bb) - 1 ^Bb, RNI @ P + 1 

5-31 

ISE 

04 

y 

If y = 0, RNI @ P+2, otherwise RNI @ 

P + 1 

5-28 

ISE 

04 

y.b 

If y = (B^), RNI @ P + 2, otherwise RNI 
@ P + 1 

5-28 

ISG 

05 

y 

If y = 0, RNI @ P + 2, otherwise RNI @ 

P + 1 

5-30 

ISG 

05 

y.b 

If (B^) >y, RNI @ P + 2, otherwise RNT 
@ P + 1 

5-30 

ISI 

10 

y.b 

If mb) = y, clear B*^ and RNI @ P + 2; if 
(pb) f y, (Bb) + 1 - Bb, RNI @ P + 1 

5-31 

JAA 

77 


Last executed jump address -*A 

JUMP ADDRESS TO A 

5-40 

JMP,HI 

70 

m 

Jump if BDP condition register >0 or + 

5-42 

JMP, 

LOW 

70 

m 

Jump if BDP condition register < 0 or - 

5-42 

JMP, 

ZRO 

70 

m 

Jump if BDP condition register = 0 

5-42 
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table 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont'd) 


Mnemonic 

Code 

Basic 

Octal 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

LACK 

22 

r, 1 

(R) -^A; load lower 6 bits of A 

5-49 

LBR 

70 

m 

Load BCR and restore BDP conditions 
from data at 'm' 

5-155 

LCA,I 

24 

m,b 

(M) - A 

5-50 

LCAQ.I 

26 

m, b 

(M) -A, (M + 1) -Q 

5-51 

LDA,I 

20 

m,b 

(M) -A 

5-49 

LDAQ,I 

25 

m,b 

(M) -A, (M + 1) -*Q 

5-50 

LDI,I 

54 

m,b 

(Moo- 14 ) 

5-52 

LDL,I 

27 

m, b 

(M) A (Q) -^A 

5-50 

LDQ,I 

21 

m, b 

(M) -^Q 

5-51 

LPA,I 

37 

m, b 

(M) A (A) -»A 

5-73 

LQCH 

23 

r ,2 

(R) load lower 6 bits of Q 

5-52 

MEQ 

06 

m,i 

(B^) - i -»-B^; if (B^) negative, RNI @ 

P + 1; if (b 1) positive, test (A) = (Q) A 
(M); if true, RNI @ P + 2, if false, repeat 
sequence 

5-75 

MOVE, 

INT 

72 

S,r, s 

Move (S) characters from r to s 

5-138 

MTH 

07 

m,i 

(b 2) - i. -h-b^, if (B^) negative, RNI @ P + 

1; if (B^) positive, test (A) >(Q) A (M); 
if true, RNI @ P + 2; if false,repeat se¬ 
quence 

5-76 

MUA,I 

50 

m, b 

Multiply (A) by (M) -*QA; lowest order 
bits of product in A 

5-62 

MUAQ,I 

56 

m, b 

Multiply (AQ) by (M,M + 1) ->AQE 

5-63 

MVBF 

64 

r,B 

Si, s, 

S2 

Move characters from fid A -*fld C; if 
fid C >fld A, blank fill 

5-142 

MVE 

64 

r, B , 
Si, 

Bs. S2 

Move characters from fid A ^ fid C ac¬ 
cording to parameters given 

5-140 

MVE,DC 

64 

r, Bj^, 

s, Bg, 

S2 

Move characters from fid A -^fld C ac¬ 
cording to parameters given. Delimiting 
character possibility 

5-141 

MVZF 

64 

r, Br, 
Si, s, 
Bs, S 2 

Move characters from fid A -^fld C; if 
fid C >fld A, zero fill 

5-143 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont’d) 


Mnemonic 

Code 

Basic 

Octal 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

MVZS 

64 

r, Bj., 
Si, s, 
Bs. ^2 

- - " " 

Move characters from fid Afid C; 
suppress leading zeros 

5-144 

MVZS.DC 

64 

r, Br, 

S, Bg, 

^2 

Move characters from fid A ^ fid C; sup¬ 
press leading zeros. Delimiting character 
possibility 

5-145 

OSA 

77 


Clear A; OSR ^Aqq_q 2 

OPERAND STATE REGISTER TO A 

5-37 

OTAC, 

INT 

75 

ch 

Character from lower 6 bits of A is sent 
to peripheral device ,(A) retained 

5-109 

OTAW, 

INT 

76 

ch 

Word from lower 12 bits or all of A 
(depending on type of I/O channel) sent to 
a peripheral device 

5-110 

OUTC, 

INT,B, 

H 

75 

ch,r,s 

Storage words disassembled into 6 or 12- 
bit characters and sent to a peripheral de¬ 
vice 

5-102 

OUTW, 

INT,B,N 

PAK 

76 

66 

ch, m,n 

r',Br,S2 
m, B^ 

Words read from storage to peripheral 
device 

Pack 6-bit BCD fid A into 6-bit BCD 
fid C 

5-104 

5-121 

PAUS 

77 

X 

Sense busy lines. If "l" appears on a line 
corresponding to "l" bits in x, do not ad¬ 
vance P. If P is inhibited for longer than 

40 ms, read reject instruction from P + 1. 
If no comparison, RNI @ P + 2 

5-87 

PFA 

77 

w, 2 

Clear A, page file index -*Aqq_ 2 i 

PAGE FILE TO A 

5-39 

PRP 

77 


Same as PAUS except real time clock 
cannot increment during the pause 
PRIORITY PAUSE 

5-88 

QEL 

55 


(Q) - El 

5-36 

QSE 

04 

y 

If y = (Q), RNI @ P + 2, otherwise RNI @ 

P + 1; lower 15 bits of Q are used 

5-29 

QSE,S 

04 

y 

If y = (Q), RNI @ P + 2, otherwise RNI @ 

P + 1, sign of y is extended 

5-29 

QSG 

05 

y 

If (Q) >y, RNI @ P + 2, otherwise RNI @ 

P + 1 

5-30 

QSG,S 

05 

y 

If (Q) >y, RNI @ P + 2, otherwise RNI @ 
p + 1, sign of y is extended 

5-30 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont’d) 


Mnemonic 

Code 

Basic 

Octal 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

RAD J 

34 

m, b 

Add (M) to (A) -(M) 

5-60 

RIS 

55 


Use (ISR) in address relocation for operands 





RELOCATE TO INSTRUCTION STATE 

5-112 

ROS 

55 


Use (OSR) in address relocation for op- 





erands. RELOCATE TO OPERAND STATE 

5-112 

RTJ 

00 

m 

P + 1 -*M (address portion) RNI @ m + 1, 





return to m for P + 1 

5-47 

SACH 

42 

r,2 

^^ 00 - 05 ) 

5-54 

SBA,I 

31 

m, b 

(A) minus (M) ^A 

5-61 

SBAQ,I 

33 

m,b 

(AQ) minus (M,M + 1) -^AQ 

5-61 

SBCD 

77 


Set BCD fault logic 

5-91 

SBJP 

77 


Transfers system from Monitor State to 





Program State when next jump instruction 





is executed. SET BOUNDRY JUMP 

5-112 

SBM 

67 

r, Br, 

Subtract fid A from fid C -* fid C 

5-69 



Sls, 





Bs. %2 



SBR 

70 

m 

Store (BCR) and BDP conditions at 'm' for 





interrupt recovery 

5-115 

SCA, I 

36 

m, b 

Where (M) contains a "l" bit, complement 





the corresponding bit in A 

5-72 

SCAN. LR, 

65 

r, Bjf, 

Scans fid A from left to right, stop on = 


EQ.DC 


S2. SC 

condition. Delimiting character possibility 

5-130 

SCAN, LR 

65 

r .Br,.S2 

Scans fid A from left to right, stop on f 


NE, DC 


SC 

condition. Delimiting character possibility 

5-132 

SCAN,RL, 

65 

r, Br-, 

Scans fid A from right to left, stop on = 


EQ, DC 


S2. SC 

condition. Delimiting character possibility 

5-134 

SCAN, RL, 

65 

r, Br, 

Scans fid A from right to left, stop on 7 ^ 


NE, DC 


S2. SC 

condition. Delimiting character possibility 

5-136 

SCAN, LR, 

65 

r, Br, 

Scans fid A from left to right, stop on = 


EQ 


S2. SC 

condition 

5-129 

SCAN, LR, 

65 

r, Br, 

Scans fid A from left to right, stop on f 


NE 


S2.SC 

_ 

condition 

5-131 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont’d) 


Mnemonic 

Code 

Basic 

Octal 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

SCAN, 

RL, EQ 

65 

r, Bj,, 
S2, SC 

Scans fid A from right to left, stop on = 
condition 

5-133 

SCAN, 

RL, NE 

65 

^ ■» 
S2.SC 

Scans fid A from right to left, stop on f 
condition 

5-135 

SCAQ 

13 

k, b 

Shift (AQ) left end around until upper 2 bits 
of A are unequal. Residue K = k shift count. 
If b = 1, 2, or 3, K - if b = 0, K is 

discarded 

5-59 

SCHA,I 

46 

m,b 

(AoO-16) -^(^00-16) 

5-56 

SCIM 

77 

X 

Selectively clear Interrupt Mask Register for 
each "l" bit in x. The corresponding bit in 
the mask register is set to "O”. 

5-90 

SDL 

77 


Causes next LDA instruction to; 

1. (M) -^A 

2. Store 77777777 @ M 

SET DESTRUCTIVE LOAD 

5-113 

SEL 

77 

X, ch 

If channel ch is busy, read reject instruction 
from P + 1. If channel ch is not busy, a 12- 
bit function code is sent on channel ch with 
a function enable RNI @ P + 2 

5-96 

SERF 

77 


Set floating point fault logic 

5-91 

SHA 

12 

k, b 

Shift (A). Shift count K=k + (B^) (signs of k 
and B° extended). If bit 23 of K="l", shift 
right; complement of lower 6 bits equals 
shift magnitude. If bit 2 3 of K = "O", shift 
left; lower 6 bits equal shift magnitude. 

Left shifts end around; right shifts end off 

5-57 

SHAQ 

13 

k, b 

Shift (AQ) as one register. Shift count K = k 
+ B^^ (signs of k and Bt> extended). If bit 23 
of K = "l", shift right and complement of 
lower 6 bits equals shift magnitude. If bit 23 
of K = "O”, shift left and lower 6 bits equal 
shift magnitude. Left shifts end around; 
right shifts end off 

5-59 

SHQ 

12 

k, b 

Shift (Q), Shift count K=k + (B^) (signs of k 
and B° extended). If bit 23 of K = "l", shift 
right, complement of lower 6 bits equals 
shift magnitude. If bit 2 3 of K = "O", shift 
left, lower 6 bits equal shift magnitude. 

Left shifts end around; right shifts end off 

5-59 
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Mnemonic 

Code 

Basic 

Octal 

Code 

Address 

Field 

Instruction Description 

— 

Page 

No. 

SJl 

M 

m 

E jump key 1 is set, jump to m 

5-41 

SJ2 


m 

E jump key 2 is set, jump to m 

5-41 

SJ3 

00 

m 

E jump key 3 is set, jump to m 

5-41 

SJ4 

00 

m 

If jump key 4 is set, jump to m 

5-41 

SJ5 

00 

m 

If jump key 5 is set, jump to m 

5-41 

SJ6 

00 

m 

If jump key 6 is set, jump to m 

5-41 

SLS 

77 


Program stops if Selective Stop switch is on; 
upon restarting RNI @ P + 1 

5-24 

SQCH 

43 

r,l 

(QoO-05) 

5-55 

SRCE, 

INT 

71 

SC,r,s 

Search for equality of scan character SC in 
a field beginning at location r until an equal 
character is found, or until character loca¬ 
tion s is reached. 

5-125 

SRCN, 

INT 

71 

SC,r,s 

Same as SRCE except search condition is 
for inequality 

5-127 

SSA,I 

35 

m, b 

Where (M) contains a "l" bit, set the cor¬ 
responding bit in A to "l" 

5-72 

SSH 

10 

m 

Test sign of (m), shift (m) left one place, 
end around and replace in storage. E sign 
negative, RNI @ P + 2; otherwise RNI @ 

P + 1 

5-57 

SSIM 

77 

X 

Selectively set interrupt mask register for 
each ” 1 " bit in x. The corresponding bit in 
the mask register is set to "l" 

5-90 

STA,I 

40 

m, b 

(A) ->(M) 

5-53 

STAQ,I 

45 

m, b 

(AQ) ->(M, M + 1) 

5-54 

STI,I 

47 

m, b 

(B^’) (Mqq_24) 

5-56 

STQ,I 

41 

m, b 

(Q) --(M) 

5-55 

SWA, I 

44 

m, b 

(^00-14^ ^(Moo- 14 ) 

5-56 

TAI 

53 

b 

(^00-14) 

5-33 

TAM 

53 

V 

(A) ->v 

5-34 

TIA 

53 

b 

Clear (A), (B^) -Aoo -14 

5-33 

TIM 

53 

v,b 


5-35 

TMA 

53 

V 

(v) -*A 

5-34 
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Basic 

Octal 

Code 

Address 

Field 

Instruction Description 

Page 

No. 

TMAV 

77 


Initiate memory request. If reply occurs 
within 5 usee, RNI at P + 2; if not, RNI at 

P + 1, Storage address is (B^) with (OSR) 
or zero appended, TEST MEMORY 
AVAILABILITY 

5-81 

TMI 

53 


^^00-14^ 

5-35 

TMQ 

53 

V 

(v) -^Q 

5-34 

TQM 

53 

V 

(Q) V 

5-34 

TST 

67 

r, B 

Si 

Test fid A, +, - , or 0 

5-82 

TSTN 

67 

•’I 

Bp, 

Test fid A for numeric 

5-82. 0 

UCS 

77 


Unconditional stop. Upon restarting RNI @ 

P + 1 

5-24 

UJP, I 

01 

m, b 

Unconditional jump to M. 

5-41 

UPAK 

66 

Bg, S2 

Unpack 4-bit BCD fid A into 6-bit BCD 
fid C 

5-122 

XOA 

16 

y 

y V (A) -A, 

5-71 

XOA,S 

16 

y 

y V (A) -*A, sign of y extended 

5-71 

XOI 

16 

y.b 

y V (B^) '-b’^ 

5-71 

XOQ 

16 

y 

y V (Q) -^Q 

5-71 

XOQ,S 

16 

y 

y V (Q) -*'Q, sign of y extended 

5-71 

ZADM 

67 

r. Bp, 

Si, s, 
Bs. S 2 

Clear fid C; fid A -*fld C, right justify 

5-146 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS 


Function 


Arithmetic 


Mnemonic 

Code 

— 

Instruction Description 

Page 

No. 

ADA, I 

Add (M) to (A) -*A 

5-60 

ADAQJ 

Add (M,M + 1) to (AQ) -AQ 

5-61 

AIA 

Add (A) to (Bb) A 

5-33 

ADM 

Add fid A to fid C - fid C 

5-68 

AQA 

Add (A) to (Q) -A 

5-32 

AQE 

(AQ) -(EuEl) 

5-36 

DVA,I 

(AQ)-5- (M) — A, Remainder — Q 

5-62 

DVAQ, I 

(AQE)-r {M,M + 1) — AQ and remainder with 
sign extended to E. Divide fault halts 
operation and program advances to next 
instruction 

5-63 

FAD, I 

Floating point addition of (M,M + 1) to (AQ) 
-AQ 

5-65 

FDV,I 

Floating point division of (AQ) by (M,M + 1) 
— AQ, remainder with sign extended to E 

5-66 

FMU,I 

Floating point multiplication of (AQ) and 
(M,M + 1) —AQ 

5-66 

FSB, I 

Floatingpoint subtraction of (M,M + 1) 
from (AQ) — AQ 

5-65 

lAI 

Add (A) to (B^) — B^. Sign of b'^ extended 
prior to addition 

5-33 

INA 

Increase (A) by y 

5-27 

INA,S 

Increase (A) by y, sign extended 

5-27 

INI 

Increase (B^) by y, signs of y and B^ are 
extended 

5-27 

INQ 

Increase (Q) by y 

5-27 

INQ,S 

Increase (Q) by y, sign extended 

5-27 

MUA,I 

Multiply (M) by (A) — QA. Lowest order 
bits of product in A 

5-62 

MUAQ,I 

Multiply (AQ) by (M,M +1) — AQE 

5-63 

RAD, I 

Add (M) to (A) -(M) 

5-60 

SBA,I 

(A) minus (M) —A 

5-61 

SBAQ,I 

(AQ) minus (M,M + 1) — AQ 

5-61 

SBM 

Subtract fid A from fid C —fid C 

5-69 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 


Function 

Mnemonic 

Code 

Instruction Description 

Page 

No. 

Character 

Operation 

ATD 

Translate ASCII fid A to BCD ->fld C 

5-119 


ATD,DC 

Translate ASCH fid A to BCD ->fld C with 
delimiting character possibility 

5-120 


CMP 

Compares fid A to fid C, exits upon en¬ 
countering f characters 

5-79 


CMP, DC 

Compares fid A to fid C, exits upon en¬ 
countering f characters; delimiting char¬ 
acter possibility 

5-80 


CVBD 

Convert binary fid A to BCD -^-fld C 

5-116 


CVDB 

Convert BCD fid A to binary -♦fid C 

5-115 


DTA 

Translate BCD fid A to ASCII -*fld C 

5-117 


DTA,DC 

Translate BCD fid A to ASCII ->fld C with 
delimiting character possibility 

5-118 


ECHA 

2 "*^00-16 

5-26 


ECHA,S 

z -»A sign extended 

5-26 


EDIT 

Fid A -*fld C with COBOL type of editing 
specified by picture previously stored in 
fid C 

5-149 


FRMT 

Fid A -►fid C with editing specified by pic¬ 
ture previously stored in fid; limited to 
specific types of editing to allow processing 
in a single scan. 

5-147 


LACK 

(R) -^Aoo-05 

5-49 


LQCH 

(R) — Qoo-05 

5-52 


MVBF 

Move characters from fid A -►fid C; if fid 

C >fld A, blank fill 

5-142 


MOVE, 

INT 

Move S characters from r to s 

5-138 


MVE 

Move characters from fid A -♦fid C ac¬ 
cording to parameters given 

5-140 


MVE,DC 

Move characters from fid A -►fid C 
according to parameters given. Delimiting 
character possibility 

5-141 


MVZF 

Move characters from fid A -►fid C; if 
fid C >fld A, zero fill 

5-143 


Rev. B 


Instruction Tables - 24 












TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 


Function 

Mnemonic 

Code 

Instruction Description 

Page 

No. 

Character 

Operation 

(Cont'd) 

MVZS 

MVZS,DC 

Move characters from fid A -»-fld C; 
suppress leading zeros 

Move characters from fid A ^fld C; 
suppress leading zeros. Delimiting 
character possibility 

5-144 

5-145 


PAK 

Pack 6-bit BCD fid A into 4-bit BCD fid C 

5-121 


SACK 

^^00-05^ 

5-54 


SCAN^LR. 
EQ, DC 

Scans fid A from left to right, stop on = 
condition. Delimiting character possibility 

5-130 


SCANNER, 
NE, DC 

Scans fid A from left to right, stop on 
condition. Delimiting character possibility 

5-132 


SCAN,RL, 
EQ, DC 

Scans fid A from right to left, stop on = 
condition. Delimiting character possibility 

5-134 


SCAN,RL, 
NE, DC 

Scans fid A from right to left, stop on f 
condition. Delimiting character possibility 

5-136 


SCAN,LR, 

EQ 

Scans fid A from left to right, stop on = 
condition. 

5-129 


SCAN, LR 
NE 

Scans fid A from left to right, stop on f 
condition 

5-131 


SCAN,RL, 

EQ 

Scans fid A from right to left, stop on = 
condition 

5-133 


SCAN,RL, 

NE 

Scans fid A from right to left, stop on f 
condition 

5-135 


SCHA,I 

<■^00-16) 

5-56 


SQCH 

(^00-05^ 

5-55 


UPAK 

Unpack 4-bit BCD fid A into 6-bit BCD 
fid C 

5-122 


ZADM 

Clear fid C; fid A -’■fid C, right justify 

5-146 

Decision 

AQJ,EQ 

If (A)=(Q),RNI @ m,otherwise RNI@P+1 

5-46 


AQJ.GE 

If (A) >(Q),RNI@m,otherwise RNI@P+1 

5-46 


AQJ,LT 

If (A) < (Q), RNI @ m, otherwise RNI @ P+1 

5-46 


AQJ, NE 

If (A) f (Q), RNI@ m,otherwise RNI@P+1 

5-46 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 


Function 


Decision 

(Cont'd) 


Mnemonic 

Code 

Instruction Description 

Page 

No. 

ASE 

If y = (A), RNI @ P + 2, otherwise RNI @ ■ 

P + 1. Lower 15 bits of A are used 

5-29 

ASE.S 

If y = (A), RNI @ P + 2, otherwise RNI @ 

P + 1. Sign of y is extended 

5-29 

ASG 

If (A) >y, RNI @ P + 2, otherwise @ P+ 1 

5-30 

ASG,S 

If (A) >y, RNI @ P + 2, otherwise RNI @ 

P + 1. Sign of y is extended 

5-30 

AZJ,EQ 

If (A) = 0^ RNI @ m, otherwise RNI @ P+1 

5-45 

AZJ,GE 

If (A) >0, RNI @ m, otherwise RNI @ P+1 

5-45 

AZJ,LT 

If (A) <0, RNI @ m, otherwise RNI @ P+1 

5-45 

AZJ,NE 

If (A) f 0, RNI @ m, otherwise RNI @ P+1 

5-45 

CPR,I 

(M) >(M) RNI @ P + 1 1 o (o) 

(Q) >(M) RNI @ P + 2 ^ i^changed 

(A)>{M)>(Q) RNI@P+3j uncnangea 

5-77 

IJD 

If (B*^) = 0, RNI @ P+1; if (Bt*) ^ 0, (B^) - 1 
-*Bt>, RNI @ m 

5-44 

IJI 

If (Bt>) = 0, RNI @ P+1; if (b’^) 0, (B^) + 1 

B^, RNI @ m 

5-43 

ISD 

If (B^) = y, clear B^ and RNI @ P + 2; if B^ 
y, (Bb) - 1 ->b’=’, RNI @ P + 1 

5-31 

ISE 

If y = 0, RNI @ P+2, otherwise RNI @ 

P + 1 

5-28 

ISE 

If y = (B^), RNI @ P+2, otherwise RNI @ 

P+1 

5-28 

ISG 

If y = 0, RNI @P+2, otherwise RNI @ 

P+1 

5-30 

ISG 

If (B^) >y, RNI @ P+2, otherwise RNI @ 

P + 1 

5-30 

ISI 

If (B^) = y, clear B^ and RNI @ P+2; if 
(B^) jt (bO) + 1 - Bb, RNI @ P+1 

5-31 

SRCE,INT 

Search for equality of scan character SC in 
a field beginning at location r until equal 
character is found, or until character lo¬ 
cation s is reached 

5-125 

SRCN,INT 

Same as SRCE except search condition is 
for inequality 

5-127 

SSH 

Test sign of (m), shift (m) left one place 
end around and replace in storage. If 
sign negative, RNI @ P+2; otherwise RNI 
@ P+1 

5-57 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 


Function 

Mnemonic 

Code 

Instruction Description 

Page 

No. 

Decision 

(Cont'd) 

MEQ 

(B^) - i ^b 1; if (b 1) negative, RNI @ P+1; 
if (b 1) positive, test (A) >(Q) A (M), if true, 
RNI @ P+2, if false, repeat sequence 

5-75 


MTH 

(B^)-i ^ (B^); if (B^) negative, RNI @ P+1; 
if (b 2) positive, test (A) > (Q) A (M); if 
true, RNI @ P+2; if false, repeat sequence 

5-76 


PAUS 

Sense busy lines. If "l" appears on a line 
corresponding to "l" bits in x, do not ad¬ 
vance P. If P is inhibited for longer than 

40 ms, read reject instruction from P+1. 

If no comparison, RNI @ P+2 

5-87 


PRP 

Same as PAUS except real-time clock can¬ 
not increment during the pause 

PRIORITY PAUSE 

5-88 


QSE 

If y = (Q), RNI @ P+2,; otherwise RNI @ 

P+1. Lower 15 bits of Q are used 

5-29 


QSE,S 

If y = (Q), RNI @ P+2; otherwise RNI @ 

P+1. Sign of y is extended 

5-29 


QSG 

If (Q) >y, RNI @ P+2; otherwise RNI @ P+1 

5-30 


QSG,S 

If (Q) >y, RNI @ P+2; otherwise RNI @ 

P+1. Sign of y is extended 

5-30 


TST 

Test fid A, +, -, or 0 

5-82 

Executive 

Mode 

ACI 

A CIR 

A^feC hannel index register 

5-38 


ACR 

A^TO^^ONDITION REGISTER 

5-40 


AIS 

Aqq_o 2 ^ fSR 

A TO INSTRUCTION STATE REGISTER 

5-37 


AOS 

"^00-02 OSR 

A TO OPERAND STATE REGISTER 

5-37 


APF 

Aoo-11-^ page file 

A TO PAGE PILE 

5-39 


CIA 

Clear A; channel index register -* Agg_Q 2 

5-38 


CRA 

ISA 

Clear A; condition register"'' Ann.nir 

Clear A; ISR -h- Aqo_o2 

INSTRUCTION STATE REGISTER TO A 

5-40 

5-37 


JAA 

Last executed jump address ^ A 

JUMP ADDRESS TO A 

5-40 


OSA 

Clear A; OSR-^ ^00-02 

OPERAND STATE REGISTER TO A 

5-37 


PFA 

_ 

Clear A, page file index -> Ag„ . ^ 

PAGE FILE TO A 

5-39 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 


Function 

Mnemonic 

Code 

Instruction Description 

Page 

No. 

Executive 
Mode (Cont'd) 

RIS 

Use (ISR) in address relocation for 
operands. RELOCATE TO INSTRUCTION 
STATE 

5-112 


ROS 

Use (OSR) in address relocation for 
operands. RELOCATE TO OPERAND 

STATE 

5-112 


SBJP 

Transfers system from Monitor State to 
Program State when next jump instruction 
is executed. SET BOUNDARY JUMP 

5-112 


SDL 

Causes next LDA instruction to: 

1. (M)^A 

2. Store 77777777 @ M 

SET DESTRUCTIVE LOAD 

5-113 


TMAV 

Initiate memory request. If reply occurs 
within 5 usee, RNI @ P+2; if not, RNI @ 

P+1. Storage address is (B2) with (OSR) 
or zero appended 

TEST MEMORY AVAILABILITY 

5-81 

Input/Output 

CLCA 

Clear the specified channel, but not 
external equipment. CLEAR CHANNEL 
ACTIVITY 

5-94 


CON 

If channel ch is busy, read reject instruc¬ 
tion from P+1. If channel ch is not busy, 

12-bit connect code sent on channel ch with 
connect enable, RNI @ P+2 

5-95 


COPY 

External status code from I/O channel ch 
to lower 12-bits of A, contents of interrupt 
mask register to upper 12-bits of A. RNI 
@ P+1 

5-83 


CTI 

CTO 

Set Type In 

Set Type Out, 

Beginning character address 
must be preset in location 
> 23 of register file and last 
character address + 1 must 
be preset in location 33 of 
the file. 

5-97 


EXS 

Sense external status if "l" bits occur on 
status lines in any of the same positions 
as "l" bits in the mask, RNI @ P+1. If no 
comparison, RNI @ P + 2. 

5-83 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont’d) 


Function 

Mnemonic 

Code 

Instruction Description 

Page 

No. 

Input/ Output 
(Cont'd) 

INAC JNT 

(A) is cleared and a 6-bit character is 
transferred from a peripheral device to the 
lower 6 bits of A 

5-106 


INAWJNT 

(A) is cleared and a 12 or 24-bit word is 
read from a peripheral device into the 
lower 12 bits or all of A (Word size de¬ 
pends on I/O channel) 

5-107 


INPC JNT 
B,H,G 

A 6 or 12-bit character is read from peri¬ 
pheral device and stored in memory at a 
given location 

5-98 


INPW JNT, 
B,N,G 

Word address is placed in bits 00-14; 12- 
or 24-bit words are read from a peripheral 
device and stored in memory 

5-100 


lOCL 

Clears I/O channel or search/move control 
as defined by bits 00-03, 08,and 11 of x. 

Bits 04-07, 09,and 10 are not used 

5-94 


OTAC,INT 

Character from lower 6 bits is sent to 
peripheral device, (A) retained 

5-109 


OTAW, 

INT 

Word from lower 12 bits or all of A (de¬ 
pending on type of I/O channel) sent to a 
peripheral device 

5-110 


OUTC, 

INT,B,H 

Storage words assembled into 6 or 12-bit 
characters and sent to a peripheral device 

5-102 


OUTW, 
INT,B, N 

Words read from storage to peripheral 
device 

5-104 


SEL 

If channel ch is busy, read reject instruc¬ 
tion from P + 1. If channel ch is not busy, 
a 12-bit function code is sent on channel 
ch with a function enable, RNI @ P+2 

5-96 

Interrupt 

CILO 

Lockout external interrupt on masked 
channels (x),until channel(s) is not busy. 

5-91 


GINS 

Interrupt mask and internal status to A 

5-86 


DINT 

Disable interrupt control 

5-89 


EINT 

Interrupt control is enabled, allows one 
more instruction to be executed before 
interrupt occurs 

5-89 


lAPR 

Interrupt associated processor 

5-113 


INCL 

Interrupt faults defined by x are cleared 

5-89 


INS 

Sense internal status if "l” bits occur on 
status lines in any of the same positions as 
"1" bits in the mask, RNI @ P + 1. If no 
comparison, RNI @ P+2. 

5-85 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 


Function 

Mnemonic 

Code 

Instruction Description 

Page 

No. 

Interrupt 

(Cont'd) 

INTS 

Sense for interrupt condition; if "l" bits 
occur simultaneously in interrupt lines 
and in the interrupt mask, RNI @ P+1; if 
not, RNI @ P+2 

5-84 


LBR 

Load BCR and restore BDP conditions from 
data at 'm' 

5-155 


SBR 

Store (BCR) and BDP conditions at 'm' for 
interrupt recovery 

5-155 


SBCD 

Set BCD fault logic 

5-91 


SCIM 

Selectively clear interrupt mask register 
for each "l" bit in x. The corresponding 
bit in the mask register is set to "O". 

5-90 


SFPF 

Set floating point fault logic 

5-91 


SSIM 

Selectively set Interrupt mask register, for 
each "l" bit in x. The corresponding bit 
in the mask register set to "l". 

5-90 

Jumps and 

HLT 

Unconditional halt; RNI @ m upon restarting 

5-24 

Stops 

JMP,HI 

Jump if BDP condition register >0 or + 

5-42 


JMP.LOW 

Jump if BDP condition register < 0 or - 

5-42 


JMP.ZRO 

Jump if BDP condition register = 0 

5-42 


RTJ 

P+1 -»-m (address portion), RNI @ m+1, 
return to m for P+1 

5-47 


SJl 

If jump key 1 is set, jump to m 

5-41 


SJ2 

If jump key 2 is set, jump to m 

5-41 


SJ3 

If jump key 3 is set, jump to m 

5-41 


SJ4 

If jump key 4 is set, jump to m 

5-41 


SJ5 

If jump key 5 is set, jump to m 

5-41 


SJ6 

If jump key 6 is set, jump to m 

5-41 


SLS 

Program stops if Selective Stop switch is 
on; upon restarting, RNI @ P+1 

5-24 


ucs 

Unconditional stop. Upon restarting, RNI 
@ P+1 

5-24 


UJP,I 

Unconditional jump to m 

5-41 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 


Function 

Mnemonic 

Instruction Description 

Page 


Code 


No. 

Logical 

ANA 

y A (A) — A 

5-73 

Operations 

ANA, S 

y A (A) -*• A, sign of y extended 

5-73 


ANI 

y A (bI^) - B*^ 

5-73 


ANQ 

y A (Q) Q 

5-74, 


ANQ, S 

y A (Q) -*• Q, sign of y extended 

5-74 


LDL, I 

(M) A (Q) - A 

5-50 


LPA, I 

^(M) A (A) A 

5-73 


SCA, I 

Where (M) contains a "l", complement 
the corresponding bit in A 

5-72 


SSA, I 

Where (M) contains a "l" bit, set the 
corresponding bit in A to "l” 

5-72 


XOA 

y V (A) — A 

5-71 


XOA, S 

y V (A) A, sign of y extended 

5-71 


XOI 

y V (B*^) - B^ 

5-71 


XOQ 

y V (Q) -* Q 

5-71 


XOQ, S 

y V (Q) “*■ Q> sign of y extended 

5-71 

Shifts 

SCAQ 

Shift (AQ) left end around until upper 2 bits 
of A are unequal. Residue K = k-shift 
count. If b=l, 2, or 3, K- B°; if b = 0, K 




is discarded 

5-59 


SHA 

Shift- ^). Shift count K=k+(B^) (signs of k 
and B° extended). If bit 23 of K=''l", shift 
right; complement of lower 6 bits equals 
shift magnitude. If bit 23 of K = "O' , shift 




left; lower 6 bits equal shift magnitude. 

Left shifts end around; right shifts end off 

5-57 


SHAQ 

Shift (AQ) as one register. Shift count K = 
k + (B^) (signs of k and B° extended). If 
bit 23 of K = "l”, shift right; complement 
of lower 6 bits equals shift magnitude. If 
bit 23 of K = "O”, shift left; lower 6 bits 




equal shift magnitude. Left shifts end 
around; right shifts end off 

5-59 


SHQ 

Shift (Q). Shift count K = k H- (B*^) (signs of 
k and B® extended). If bit 23 of K = "l”, 
shift right; complement of lower 6 bits 
equals shift magnitude. If bit 23 of K = "O", 
shift left;lower 6 bits equal shift magnitude. 




Left shifts end around; right shifts end off 

5-59 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 


Function 

Mnemonic 

Code 

Instruction Description 

Page 

No. 

Shifts 

(Cont'd) 

SSH 

Test sign of (m), shift (m) left one place, 
end around and replace in storage. If sign 
negative, RNI@P+2; otherwise RNI @ 

P+1 

5-57 

Transfers 

AEU 

(A) - Ey 

5-36 


EAQ 

(Ey E^) - AQ 

5-36 


ELQ 

(E^) - Q 

5-36 


ENA 

Clear A, enter y 

5-25 


ENA, S 

Clear A, enter y, sign extended 

5-25 


ENI 

Clear b'^, enter y 

5-25 


ENQ 

Clear Q, enter y 

5-25 


ENQ, S 

Clear Q, enter y, sign extended 

5-25 


EUA 

(Ey) - A 

5-36 


LCA, I- 

(M) ^ A 

5-50 


LCAQ, I* 

(M) -> A, (M + D- Q 

5-51 


LDA, I 

(M) ^ A 

5-49 


LDAQ, I 

(M) - A, (M + 1) Q 

5-50 


LDI, I 

(Moo- 14 ) - 

5-52 


LDQ, I 

(M) - Q 

5-51 


MOVE, 

INT 

Move S characters from r to s 

5-138 


QEL 

(Q) ^ El 

5-36 


STA, I 

(A) - (M) 

5-53 


STAQ, I 

(AQ) - (M, M + 1) 

5-54 


STI, I 

(B^)- (Moo-14) 

5-56 


STQ, I 

(Q) (M) 

5-55 


SWA, I 

—i 

1 

0 

0 

t 

— 1 

1 

0 

0 

< 

5-56 


TAI 

^^00-14) - B 

5-33 


TAM 

(A) - v 

5-34 


TIA 

Clear (A), (Bb)->Aoo-i 4 

5-33 


TIM 

_ 

(b'^) -*■ Voo-14 

5-35 


* Requires additional operation prior to transfer. 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 


Function 

Mnemonic 

Code 

Instruction Description 

Page 

No. 

Transfers 

TMA 

(v)- A 

5-34 

(Cont'd) 

TMI 

^^ 00 - 14 ) 

5-35 


TMQ 

(v) ^ Q 

5-34 


TQM 

(Q) ^ V 

5-34 
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A register, 1-5 

display, 7-1, 7-2 
manual entry, 7-12 
Access keyboard, 7-2, 7-9, 7-10 
Accummulator, see A register 
Active Digit indicator, 7-2 
Adapt, 6-6, 6-8 
Address modification, 5-6 
examples, 5-9 
Addressing, 2-5 

character, 5-4, 5-5 
conversion, 5-5 
Direct, 5-7 
Indirect, 5-8, 5-9 
modes, 2-4, 2-5, 5-7 
relocation, E-3 
word, 5-4, 5-5 

see also Indexing, Address Modification 
ALGOL, 6-3 

Applications software, 6-6 
Arithmetic, 

BCD, F-4 
functions, P-4 
interrupt, 4-2, 4-8 
Overflow fault, 4-2 
Reference information, B-1 
register, see A register 
ASCI], F-3 

conversion table. A-3 

Associated Processor interrupt, 4-3, 4-7, 4-8 
Auto Dump, 3-7, 4-4 

address protection, 2-6 
execution, 7-16 
switch description, 7-7 
Auto Load, 3-7, 4-4 

address protection, 2-6 
execution, 7-16 
switch description, 7-7 


Backgrounding, 6-2 
B“ registers, 1-6, 5-6 
display, 7-1, 7-2 
BCD, F-3 

conversion table, A-3 
fault, 4- 2 

internal, external codes, A-1 
word and character format, F-5 
BCR, see Business Data Processor Condition register 
Binary number system, B- 1 
Block control, 1-9, 2-8, 7-19 
priority, 1-10 
s canning pattern, 1-11 
Breakpoint switch, 1-9, 7-11 
examples, 7-17, 7-18 
Business Data Processor, 

Condition register, 1-14, 5-3 
description, 1-4 
instruction forniat, 5-6 
instruction list, 1-13 
Mode switch, 7-8 
trapped instructions, 4-6 


C register, 1-6 

display, 7-1, 7-2 
CR, see Condition register 
Central Processor Unit (CPU), 1-3 
internal organization, 1-5 
operation in Executive Mode, 1-9 
module location, 1-2 
Channel, see Input/Output 
Channel Index register, 1-7, 5-3 
Character addressing, 5-4, 5-5 
designators, 1-5 
modes, 2-4, 2-5 
set, A-1 

CIR, see Channel Index register 
COBOL, 1-1, 6-3, 6-4 
Coefficient, B-8 
COMPASS, 6-3, 6-4, 6-5 
Condition register, 5-3 
Connect, 3-4, 3-5, 5-95. 0, 5-95. 1 
Console, 1-4, 7-1 
Constants, C-4, C-5 
Conversion tables, 

BCD/ASCII, A-3 
Octal-Decimal Integer, C-6 
Octal-Decimal Fraction, C-10 
Conversions, 
address, 5-5 

Fixed Point/Floating Point, B-13 
procedure, B-5 


DC, see delimiting character 
Data, 

bus, 1-8, 7-19, 7-22 
Bus register, 1-8 
entry, 7-2 

Interchange Display, 7-4 
processing, F-1 
Processing Package, 6-3, 6-5 
Decimal/Binary position table, C-2 
Decimal/Octal conversion, 
procedures, B-5 
table, C-6 

Delimiting, 1-4, F-1 
character, 5-2, 5-6 
Divide fault, 4-2 

interrupt code, 4- 10 
priority, 4-8 
Division, 

binary, B-4 
Floatingpoint, B-9 
Double Precision Arithmetic, B-8 


E Bit, see Exclusion bit 
E register, 1-6, 4-2, 7-10 
Emergency Off switch, 7-1, 7-9, 7-12 
Exclusion bit, 4-4, E-10 
Executive Mode, 1-7 
addressing, 2-5 
description, 1-9 
interrupt, 4-1, 4-3 
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Monitor State, E-1, E-6 
Program State, E-1, E-6 
switch, 7-7 
Exponent, 

Fault, 4-2, 4-8, 4-10, B-13 
floating point, B-9 


F register, 1-7, 1-9 
display, 7-1, 7-2 
Fixed Point Arithmetic, B-8 
Floating Point, 
arithmetic, B-9 
fault, 4-2, 4-8, 4-10, B-13 
module, 1-4 
E register, 1-6 
FORTRAN, 6-3 

Function, 3-4, 3-5, 5-96. 0, 5-96. 1 
codes, see instruction 


Trapped, 5-11 
Interface signals, 3-3, 7-8 
parity, 1-13 

Internal organization, 1-5 
Interrupt, 

clearing, 4-9 
codes, 4-10 
conditions, 4-2 
lines, 3-3 

Mask register, 4-10, 4-11 
priority, 4-8 
processing, 4-9, 4-10 
sensing, 4-9 
system information, 4- 1 


Jump, 

switches, 7-7 
see instructions 


ISR, see Instruction State register 
Illegal Write, 2-5 
Indicator, 7-6 

interrupt, 4-1, 4-4, 4-5, 4-6, E-10 
Indexing, 

“ examples, 5-9 
see address modification 
Index registers, 1-6, 1-14, 5-2, 5-6, 5-7 
Indirect Addressing, 
parameters, 5-1 
also see addressing 
Input / Output, 

channels, 3-1, 3-4 
disk, 6-2 

interface signals, 3-3 
interrupts, 4-1, 4-3 
modules, 1-3 
parity, 1-12, 1-13, 3-4 
software, 6-5 

system description, 3-1, 3-2 
Instruction State register, 1-7, 2-5 
display, 7-1, 7-3 
Instructions, 5-1 
Arithmetic, 5-60 
Character Search, 5- 124 
Condition Test, 5-81 
Conversion, 5-114 
Enter, 5-25 
execution times, 5-19 
formats, 5-4, 5-6, D-1 
Halt and Stop, 5-24 
Increase, 5-27 
Input / Output, 5-92 
Inter-Register Transfer, 5-32 
Interrupt, 5-89 
Jump, 5-41 
list (BDP), 1-13 
Load, 5-49 
Logical, 5-70 

Masked Search and Compare, 5-75 
Move, 5-137 

Multiprocessing Control, 5-113 
No-Operation, 5-18 
parameters, 5-1 
Pause, 5-87 

Relocation Control, 5-112 

Sensing, 5-83 

Shift and Scale, 5-57 

Skip, 5-28 

Store, 5-53 

synops is and index, 5-12 


Languages, 6-3, 6-4, 6-5 
Last Jump Address switch, 7-8 
Library tape, 6-1, 6-2 
Loudspeaker, 7-12 


MCS, see storage 

MSIO, 1-1, 6-6 

MSOS, 6-1, 6-2 

Main Control, 1-6, 2-8 

Manual Interrupt, 4- 1 

Mass Storage COBOL, 6-3, 6-4 

Mass Storage SORT, 6-6, 6-7 

MASTER, 1-1, 6-1, 6-2 

Meters, 

elapsed time, 7-24 
storage control, 2-3 
Modules, 1-2, 1-3, 2-5 
Modulus, B-1 

Monitor State, 1-9, 4-1, 4-4, 4-5, E-1 
indicator, 7-5 
Multiplication, 
binary, B- 4 
fixed point, B-8 
floating point, B-9 
Multiprogramming, 1-1 

module, 1-2, 1-4, 2-5, E-1 


No-Operation instructions, 4-6, 5-18 
Non-Executive Mode, 1-9, 2-5, 3-7, 4-4 
description, 1-9 
trapped instructions, 4-5 
Normalizing, B-13 
Number Systems, B-1 


OSR, see Operand State register 
Octal arithmetic matrices, C-3 
Octal number system, B-2 
Operand State register, 1-7 
application, E-2, E-4, E-5 
display, 7-3 

Operating systems, 6-1, 6-2 
Overflow fault, 4-2, B-13 


P register, 1-6, 2-5 
display, 7-1, 7-2 
PIF, see Page Index Pile 
Page, 

Index File, E-7 
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Index registers, E-7 
Length (PL), E-12 
memory, 2-5, E-3 
Partial (PP) , E-12 
structure, E-3 
Zero, E- 14 

Parameters, see instructions 
Parity, 1-12 

Error indicator, 7-4, 7-6 
Error interrupt, 4-1, 4-4, 4-5, 4-6 
Error signal, 3-5 
Interrupt switch, 7-7 
I/O, 1-13, 3-4, 3-5, 3-6 
storage, 1-12, 2-4 
Stop switch, 7-7 
Peripheral equipment, 1-14 
PERT, 6-6, 6-7 
Power Control Panel, 1-5 
Powerfail interrupt, 4-1, 4-7 
Program, 

Address Group, E-3 

protection, 2-7 

State, see Monitor State 


Q register, 1-5 
display, 7-1, 7-2 


REGINA-I, 6-6, 6-7 
Radix, B-1 

Read next instruction (RND, 5-11 
Real-Time Clock, 1-10, 1-11, 1-12 
interrupt, 4-3, 4-8, 4-10 
Real-Time SCOPE, 6-1, 6-2 
Register File, 7-19 
Assignments, 1-10 
breakpoint operation, 7-12, 7-17 
description, 1-9 
Registers, 

abbreviations, 5-3 
description, 1-5 
Relocation, 2-5, 3-7, E-1 
Report Generator, 6-3, 6-5 
RESPOND/MSOS, 6-6 
Rounding, B-12 


S register, 1-8, 2-1 
SCOPE 

Real-Time, 6-1, 6-2 
Utility Routines, 6-1, 6-2 
Search, F-3 

Search/Move interrupt, 4-3 
codes, 4-10 
priority, 4-8 
SIPP, 6-6 
Software, 6-1 
SORT, 6-6 
Stacked jobs, 6-2 
Status, display, 7-1, 7-4 
Storage, 2-1 

access switches, 7-11 

addressing, 2-5 

Control panel, 2-2 

modules, 1-3, 2-1 

module photographs, 2-2, 2-3 

parity, 1-12 

parity error, 4-4 

protection, 2-5 

registers, 1-8, 2-1 

sharing, 2-8 

word, 2-4 

Switches, see console 


Time-Sharing, 1-1, 6-2, E-1 
Trapped instructions, 4-6, 5-11 
interrupts, 4-6, 4-7 
Typewriter, 7-1, 7-19 
codes, 7-23 

control switches, 7-19, 7-21 


Underflow fault, 4-2, B-13 


Word Addressing, see Addressing 
Word format, 1-5 
Write, 3-4, 3-5 


Z register, 1-8, 2-1 


S bus, 1-8, 2-5 
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QUICK REFERENCE INSTRUCTION INDEX 


Instruction Category 

NO-OPERATION 
HALT and STOP 
ENTER 
INCREASE 
SKIP 

INTER-REGISTER TRANSFER 

JUMPS 

LOAD 

STORE 

SHIFT and SCALE 

ARITHMETIC 

LOGICAL 

SEARCH 

COMPARE 

TEST 

SENSING 

PAUSE 

INTERRUPT 

INPUT/OUTPUT 

RELOCATION CONTROL 

MULTI-PROCESSING CONTROL 

CONVERSION 

MOVE 


Applicable Pages 

5-19 

5-24 

5-25 through 5-26 
5-27 

5-28 through 5-31 
5-32 through 5-40 
5-41 through 5-48 
5-49 through 5-52 and 5-155 
5-53 through 5-56 and 5-155 
5-57 through 5-59 
5-60 through 5-69 
5-70 through 5-74 
5-75, 5-76, and 5-124 through 5-136 
5-7 5 through 5-80 
5-81 through 5-82 
5-83 through 5-86 
5-87 through 5-88 
5-89 through 5-91 
5-92 through 5-111 
5-112 
5-113 

5-114 through 5-136 
5-137 through 5-154 


ADDITIONAL INSTRUCTION INFORMATION 


Instruction Parameters 
Register and Function Abbreviations 
Execution Time Table 
Octal Instruction Listing 
Alphamnemonic Instruction Listing 
Instruction Function Listing 
Trapped Instruction Listing 


5-1 through 5-3 
5-3 
5-19 

Instruction Tables 1 through 11 
Instruction Tables 12 through 22 
Instruction Tables 23 through 33 

4-5 
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